当前位置: 首页 > news >正文

现代网站开发建设流程dw做网站步骤

现代网站开发建设流程,dw做网站步骤,网站的建设与管理暂行办法,广东省网站设计与开发仿写tomcat的Servlet接口体系 之前写过一篇博客#xff0c;Tomcat的Servlet-GenericServlet-HttpServlet体系的具体结构#xff0c;以及Servlet的生命周期 Servlet讲解 想要模仿tomcat获取动态资源#xff0c;就需要我们自己仿写一个Servlet接口体系 主要包括#xff1a…仿写tomcat的Servlet接口体系 之前写过一篇博客Tomcat的Servlet-GenericServlet-HttpServlet体系的具体结构以及Servlet的生命周期 Servlet讲解 想要模仿tomcat获取动态资源就需要我们自己仿写一个Servlet接口体系 主要包括注解相关的接口子类搜索包名下的所有servlet的工具类 MyWebServlet注解 我们首先需要定义一个MyWebServlet注解仿照了WebServlet注解 import java.lang.annotation.*;Target({ElementType.TYPE})// 作用到类 Retention(RetentionPolicy.RUNTIME)// 运行阶段 public interface MyWebServlet {// 定义url变量并规定默认值为空字符String className() default ;String url() default ; }相关的接口子类 MyServlet接口定义了Servlet的生命周期 import java.io.IOException;import com.qcby.config.MyServletConfig;// 自定义的servlet接口 public interface MyServlet {void init();MyServletConfig getServletConfig();String getServletInfo();void service(Request request, Response response) throws IOException;void destroy(); }自定义的MyServletConfig类 /*** 将获取到的url和classPath径封装到该对象当中*/ public class MyServletConfig {private String url;private String classPath;public MyServletConfig(String url, String classPath) {this.url url;this.classPath classPath;}public MyServletConfig() {}public String getUrl() {return url;}public void setUrl(String url) {this.url url;}public String getClassPath() {return classPath;}public void setClassPath(String classPath) {this.classPath classPath;} }抽象类MyGenericServlet实现了除service以外的方法 import com.qcby.config.MyServletConfig;public abstract class MyGenericServlet implements MyServlet {Overridepublic void init() {}Overridepublic MyServletConfig getServletConfig() {return new MyServletConfig();}Overridepublic String getServletInfo() {return ;}Overridepublic void destroy() {} }抽象类MyHttpServlet实现了service方法并将其分化为doGetdoPostdoDelete等方法 import java.io.IOException;public abstract class MyHttpServlet extends MyGenericServlet {// 重写service方法将其分化为不同的方法// 抽象类MyHttpServlet没有抽象方法Overridepublic void service(Request request, Response response) throws IOException {// 判断request的methodType转发到doGet/doPost当中if (GET.equals(request.getMethodType())) {myDoGet(request, response);} else if (POST.equals(request.getMethodType())) {myDoPost(request, response);}}public void myDoGet(MyHttpServletRequest req, MyHttpServletResponse resp) throws IOException {}public void myDoPost(MyHttpServletRequest req, MyHttpServletResponse resp) throws IOException {}}这里的MyHttpServletRequest还有MyHttpServletResponse是两个接口 public interface MyHttpServletRequest { } public interface MyHttpServletResponse {void write(String context) throws IOException; }分别由Request类和Response类实现 public class Request implements MyHttpServletRequest{private String url;private String methodType;public String getUrl() {return url;}public void setUrl(String url) {this.url url;}public String getMethodType() {return methodType;}public void setMethodType(String methodType) {this.methodType methodType;} } /*** 做数据的返回*/ public class Response implements MyHttpServletResponse {// 获取输出流private OutputStream outputStream;public Response(OutputStream outputStream) {this.outputStream outputStream;}// 静态资源的输出public void writeHtml(String path) throws Exception {//// 根据路径返回资源路径地址例如http://localhost:8666/index.htmlString resource FileUtil.getResoucePath(path);File file new File(resource);if (file.exists()) {// 静态资源存在System.out.println(静态资源存在);FileUtil.writeFile(file, outputStream);} else {System.out.println(path 对应的该静态资源不存在);}}// 数据写回public void write(String context) throws IOException {outputStream.write(context.getBytes());outputStream.flush();} }加载servlet包下的所有servlet并将其MyWebServlet注解的url值和对应的servlet类对象组装成一个map最重要 上面基本都是照猫画葫芦的仿写其实该实现的方法完全没实现跟原本的tomcat相比差的比较多 但是这一部分还原度比较高tomcat本身也是扫描包并且反射获取注解的取值最后组成HashMap来映射servlet的 SearchClassUtil /*** 扫描指定包获取该包下所有的类的全路径信息*/ public class SearchClassUtil {public static ListString classPaths new ArrayListString();public static ListString searchClass(){//需要扫描的包名String basePack com.qcby.webapp;//将获取到的包名转换为路径String classPath SearchClassUtil.class.getResource(/).getPath();basePack basePack.replace(., File.separator);String searchPath classPath basePack;doPath(new File(searchPath),classPath);//这个时候我们已经得到了指定包下所有的类的绝对路径了。我们现在利用这些绝对路径和java的反射机制得到他们的类对象return classPaths;}/*** 该方法会得到所有的类将类的绝对路径写入到classPaths中* param file*/private static void doPath(File file,String classpath) {if (file.isDirectory()) {//文件夹//文件夹我们就递归File[] files file.listFiles();for (File f1 : files) {doPath(f1,classpath);}} else {//标准文件//标准文件我们就判断是否是class文件if (file.getName().endsWith(.class)) {String path file.getPath().replace(classpath.replace(/,\\).replaceFirst(\\\\,),).replace(\\,.).replace(.class,);//如果是class文件我们就放入我们的集合中。classPaths.add(path);}}}public static void main(String[] args) {ListString classes SearchClassUtil.searchClass();for (String s: classes) {System.out.println(s);}} } tomcat启动类 对静态资源和动态资源做了判断 package com.qcby.tomcatDemo;import java.io.*; import java.net.ServerSocket; import java.net.Socket; import java.net.URLDecoder;import com.qcby.config.ServletConfigMapping; import com.qcby.servlet.MyServlet; import com.qcby.servlet.Request; import com.qcby.servlet.Response; import com.qcby.util.ResponseUtil;/*** tomcat启动类*/ public class TomcatStart {private static Request request new Request();public static void main(String[] args) throws IOException, ClassNotFoundException {System.out.println(socket服务器启动);// 0. 加载servlet类信息ServletConfigMapping.init();// 1. 打开相关通信端口// tomcat:8080,mysql:3306,应用软件独占一个端口的全部信息ServerSocket serverSocket new ServerSocket(8666);// 线程持续扫描当前网卡xxxx端口(死循环)如果有数据就拿过来交给端口对应的程序处理// 2. 监听并接收请求数据while (true) {// 一旦发现有数据就打开socket通信// 这里没有创建新的线程所以这里是main线程监听数据Socket socket serverSocket.accept();System.out.println(socket.getInetAddress().getCanonicalHostName() 进行了连接);// 第二步监听并接收到了数据处理数据可以用主线程但是没必要创建子线程处理// 每接收一次数据创建一个子线程Thread t1 new Thread(() - {// 处理数据包括两部分读和写try {dataHandle(socket);} catch (Exception e) {throw new RuntimeException(e);}});t1.start();}}// 处理数据的方法读写public static void dataHandle(Socket socket) throws Exception {// 1. 读取请求的数据// 1.1打开输入流对象读取socket对象中的数据这里的数据都是0101010的二进制数据InputStream inputStream socket.getInputStream();requestContext(inputStream);// 数据的输出Response response new Response(socket.getOutputStream());if (.equals(request.getUrl())) {response.write(ResponseUtil._404ResponseHeader);} else if (ServletConfigMapping.classMap.get(request.getUrl()) ! null) {// 动态web资源dispatch(request, response);} else {// 访问静态资源response.writeHtml(request.getUrl());}}public static void dispatch(Request request, Response response) throws InstantiationException, IllegalAccessException, IOException {ClassMyServlet servletClass ServletConfigMapping.classMap.get(request.getUrl());if (servletClass ! null) {MyServlet myServlet servletClass.newInstance();myServlet.service(request, response);}}public static void requestContext(InputStream inputStream) throws IOException {// 1.2 二进制数据的翻译并读取int count 0;while (count 0) {// 返回此输入流下一个方法调用可以不受阻塞地从此输入流读取或跳过的估计字节数。// 下一个调用可能是同一个线程也可能是另一个线程。// 一次读取或跳过此估计数个字节不会受阻塞但读取或跳过的字节数可能小于该数。// 可以不受阻塞地从此输入流读取或跳过的估计字节数如果到达输入流末尾则返回 0count inputStream.available();}byte[] bytes new byte[count];inputStream.read(bytes);// 这里用URLDecoder是为了防止路径中出现特殊符号经过get请求之后会被URLEncode为乱码String context URLDecoder.decode(new String(bytes, utf-8));// Base64.getDecoder().decode(bytes)System.out.println(context: context);if (.equals(context)) {System.out.println(null request!);request.setUrl();request.setMethodType();} else {//根据换行来获取第一行数据String firstLine context.split(\\n)[0];// 第一行数据的第2个字符串System.out.println(url: firstLine.split(\\s)[1]);request.setUrl(firstLine.split(\\s)[1]);// 第一行数据的第1个字符串System.out.println(methodType: firstLine.split(\\s)[0]);request.setMethodType(firstLine.split(\\s)[0]);}} }webapp包下有两个servlet MyWebServlet(url /first) public class FirstServlet extends MyHttpServlet {Overridepublic void myDoGet(MyHttpServletRequest req, MyHttpServletResponse resp) throws IOException {String context h1这是FirstServlet的myDoGet方法/h1;resp.write(ResponseUtil.makeResponse(context, ResponseUtil.htmlResponseHeader));}Overridepublic void myDoPost(MyHttpServletRequest req, MyHttpServletResponse resp) throws IOException {String context h1这是FirstServlet的myDoPost方法/h1;resp.write(ResponseUtil.makeResponse(context, ResponseUtil.htmlResponseHeader));} }MyWebServlet(url /hello) public class HelloServlet extends MyHttpServlet {Overridepublic void myDoGet(MyHttpServletRequest req, MyHttpServletResponse resp) throws IOException {String context h1这是HelloServlet的myDoGet方法/h1;resp.write(ResponseUtil.makeResponse(context, ResponseUtil.htmlResponseHeader));}Overridepublic void myDoPost(MyHttpServletRequest req, MyHttpServletResponse resp) throws IOException {String context h1这是HelloServlet的myDoPost方法/h1;resp.write(ResponseUtil.makeResponse(context, ResponseUtil.htmlResponseHeader));} }项目下还有一个静态资源index.html !DOCTYPE html html langen headmeta charsetUTF-8titleTitle/title /head bodypHello TomcatDemo!!!/p /body /html我们在浏览器分别测试静态和动态资源的获取
http://www.dnsts.com.cn/news/238201.html

相关文章:

  • 什么身一什么网站建设青岛哪家做网站的公司好
  • 怎么查一个网站的外链为企业推广
  • 象山县建设工程招投标网站网站文章收录查询
  • 使用tag的网站怎么看网站有没有做推广
  • 安徽安搜做的网站怎么样成都小企业网站设计
  • 商城网站建设价位wordpress导出xml
  • 公司网站模版 dedecms店铺推广渠道
  • 网站建设职业描述移动端wordpress主题
  • dw网站制作的源代码抚州市网站建设
  • 找网站开发wordpress cosy主题2.05
  • 国际域名查询网站建立公司的流程
  • 仿美团网站开发免费的网站平台
  • wordpress加cnzz哈尔滨seo搜索排名优化公司
  • 做新房什么网站好wordpress 做的官网
  • 网站建设用款做网站编程时容易遇到的问题
  • 网站的域名在哪里看seo 网站结构优化
  • 化妆品营销型网站模板动漫做3d游戏下载网站有哪些
  • 无锡优化网站个人如何做商城网站
  • 建设网站的源代码的所有权如何制作网页脚本
  • 怎样写精品课程网站建设微站平台
  • 网站背景色代码百度seo优化网站
  • 如何做网站宣传自己网站打开速度优化
  • 深圳专业商城网站制作公司做网站竞品分析
  • 群辉怎么做视频网站天津网架公司
  • 国内最好的旅游网站自助建站编辑器
  • 网站提升收录新余市建设局网站
  • wordpress搭建软件下载谷歌推广优化
  • 网站美工设计详细步骤百度账号一键登录
  • 电子商务网站建设 期末考试试卷以及答案上海市工程建设协会网站
  • 我的世界查询建筑网站广西壮族自治区工商行政管理局