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

移动端网站开发标题设置企业网站的基本内容有哪些

移动端网站开发标题设置,企业网站的基本内容有哪些,大学网站建设包括哪些课程,手机创建自己网站#x1f4e2; 大家好#xff0c;我是 【战神刘玉栋】#xff0c;有10多年的研发经验#xff0c;致力于前后端技术栈的知识沉淀和传播。 #x1f497; #x1f33b; CSDN入驻不久#xff0c;希望大家多多支持#xff0c;后续会继续提升文章质量#xff0c;绝不滥竽充数… 大家好我是 【战神刘玉栋】有10多年的研发经验致力于前后端技术栈的知识沉淀和传播。 CSDN入驻不久希望大家多多支持后续会继续提升文章质量绝不滥竽充数欢迎多多交流。 文章目录 写在前面的话学前准备 请求流程分析Step1、DispatcherServlet#doDispatchStep2、DispatcherServlet#getHandlerStep3、DispatcherServlet#getHandlerAdapterStep4、DispatcherServlet#handleStep5、InvocableHandlerMethod#getMethodArgumentValuesStep6、RequestResponseBodyMethodProcessor#readWithMessageConvertersStep7、RequestResponseBodyMethodProcessor#readWithMessageConverters 请求分析复盘整个流程梳理精简版doDispatch部分源码 总结陈词 写在前面的话 通过上一篇博文《学会 SpringMVC 系列 · 基础篇》的学习可以掌握 SpringMVC 的项目搭建和部分用法从搭建过程中我们看到SpringMVC 的入口是在 web.xml 中添加 DispatcherServlet它是一个Servlet那请求流程也遵循 Servlet 相关规范展开。 接下来让我们进一步分析相关源码顺带引出相关扩展点和实战运用。 学前准备 1、SpringMVC 源码分析分为初始化流程和请求流程两部分本篇先重点介绍后者。可以把 SpringMVC的请求流程比作一个请求Servlet的完整生命周期那就是包括“请求前 - 实际请求 - 请求后”以此思路展开。 2、本篇 SpringMVC 源码分析系列文章将以 《搭建拥有数据交互的 SpringBoot 》的 SpringBoot3.x 为基础学习相关源码对应 SpringMVC 版本为 6.1.11不过核心流程上基本大同小异。 3、先添加一个入参和返回值都是String的简单接口如下麻雀虽小但也覆盖到入参解析逻辑了启动Boot项目Postman测试一下就可以开始学习了。 ResponseBody RequestMapping(/studyJson) public ZyTeacherInfo studyJson(RequestBody ZyTeacherInfo teacherInfo) {teacherInfo.setTeaName(战神);return teacherInfo; }请求流程分析 Tips先梳理一下本方法的完整链路在此基础上扩展自定义逻辑试试。 Step1、DispatcherServlet#doDispatch 前面提到 DispatcherServlet 是 SpringMVC 的入口不管是否 SpringBoot从下面这张图很明显可以看出 DispatcherServlet 和 Servlet 的父子关系。 有过 JavaWeb 开发经验的人应该了解Servlet 的请求入口方法是 service 方法访问接口后一步步往后跟当断点停留在 DispatcherServlet#doDispatch 方法的时候可以从IDEA的调试器观察到请求顺序的堆栈信息。 这边先不展开细节后续在按专栏展开总之是在 DispatcherServlet、FrameworkServlet、HttpServlet 等类之间反复横跳最后到了 doDispatch这里面才是请求的核心逻辑。 Step2、DispatcherServlet#getHandler 关键代码HandlerExecutionChain mappedHandler getHandler(processedRequest); 逻辑说明 目的是获取 HandlerExecutionChain 执行链对象除了包含 HandlerMethod 方法对象外还包含拦截器信息如下图所示有多个 HandlerMapping 对象当然最终这里里面找到了 RequestMappingHandlerMapping 目前大部分开发都使用 RequestMapping示例方法也是如此因此看名字就知道走的是 RequestMappingHandlerMapping当然从RequestMappingHandlerMapping#isHandler 的代码也可以看出来只要类包含Controller注解就可以满足。 TipsSpringMVC的5.x也允许只存在 RequestMapping 注解的情况6.x 只剩下Controller了。 protected boolean isHandler(Class? beanType) {return AnnotatedElementUtils.hasAnnotation(beanType, Controller.class); }这里回到断点如下获取到的HandlerExecutionChain对象如下指向具体业务接口并且包含三个内置拦截器。 到此DispatcherServlet#getHandler 流程结束。 补充一下RequestMappingHandlerMapping 会在初始化的时候会将url/controller的映射存到handlerMethods 变量中url/mapping的映射存在urlMap变量中如下所示目的是方便快速查找。 private final MapT, HandlerMethod handlerMethods new LinkedHashMapT, HandlerMethod(); private final MultiValueMapString, T urlMap new LinkedMultiValueMapString, T();温馨提示很多代码善可继续深挖但建议分析源码还是要把握主线不然深陷其中无法自拔。 Step3、DispatcherServlet#getHandlerAdapter 关键代码HandlerAdapter ha getHandlerAdapter(mappedHandler.getHandler()); 逻辑说明 目的是获取 HandlerAdapter 适配器对象逻辑有点类似前面找Mapping如下图所示最终从若干里面找到合适的 RequestMappingHandlerAdapter 从代码也可以看出是根据 supports 方法判断 adapter 是否支持这个 handler很明显这个要求很简单RequestMappingHandlerAdapter 是肯定满足的 // 存在父类 AbstractHandlerMethodAdapter#supports public final boolean supports(Object handler) {//判断handler是否属于HandlerMethod 并且 supportsInternal 为truereturn (handler instanceof HandlerMethod supportsInternal((HandlerMethod) handler)); }getHandlerAdapter 也可以添加如下注释信息看起来和前面获取 HandlerExecutionChain 差不多 protected HandlerAdapter getHandlerAdapter(Object handler) throws ServletException {//遍历所有handlerAdapters 选择合适的handlerAdaptersfor (HandlerAdapter ha : this.handlerAdapters) {if (logger.isTraceEnabled()) {logger.trace(Testing handler adapter [ ha ]);}//判断这个adapter是否支持这个handlerif (ha.supports(handler)) {return ha;}}throw new ServletException(No adapter for handler [ handler ]: The DispatcherServlet configuration needs to include a HandlerAdapter that supports this handler); } Step4、DispatcherServlet#handle 直接上一下示例代码如下 if (!mappedHandler.applyPreHandle(processedRequest, response)) {return; }// Actually invoke the handler. mv ha.handle(processedRequest, response, mappedHandler.getHandler());mappedHandler.applyPostHandle(processedRequest, response, mv);功能说明 1、此时已经得到 HandlerAdapter先执行所有拦截器的 applyPreHandle 方法 2、接着调用其 handle 方法再执行拦截器的 applyPostHandle 方法 3、这里的 handle 是主要逻辑由于 RequestMappingHandlerAdapter 没有 handle 方法所以进入父类的 handle再经过一系列方法最终进入InvocableHandlerMethod#invokeForRequest //请求链路 //AbstractHandlerMethodAdapter#handle //RequestMappingHandlerAdapter#invokeHandleMethod //ServletInvocableHandlerMethod#invokeAndHandle //InvocableHandlerMethod#invokeForRequest public final Object invokeForRequest(NativeWebRequest request, ModelAndViewContainer mavContainer,Object... providedArgs) throws Exception {// 得到参数Object[] args getMethodArgumentValues(request, mavContainer, providedArgs);if (logger.isTraceEnabled()) {StringBuilder sb new StringBuilder(Invoking [);sb.append(getBeanType().getSimpleName()).append(.);sb.append(getMethod().getName()).append(] method with arguments );sb.append(Arrays.asList(args));logger.trace(sb.toString());}//此处执行反射调用controller的方法Object returnValue doInvoke(args);if (logger.isTraceEnabled()) {logger.trace(Method [ getMethod().getName() ] returned [ returnValue ]);}return returnValue; }Step5、InvocableHandlerMethod#getMethodArgumentValues getMethodArgumentValues 这步通俗一点来说就是解析参数得到最后的参数列表。 部分代码如下所示 protected Object[] getMethodArgumentValues(NativeWebRequest request, Nullable ModelAndViewContainer mavContainer,Object... providedArgs) throws Exception {Object[] args new Object[parameters.length];for (int i 0; i parameters.length; i) {// 判断是否支持解析这个参数如果支持会把参数解析器加入到缓存中if (!this.resolvers.supportsParameter(parameter)) {throw new IllegalStateException(formatArgumentError(parameter, No suitable resolver));}try {解析请求参数args[i] this.resolvers.resolveArgument(parameter, mavContainer, request, this.dataBinderFactory);}}return args; }其中最重要的方法应该是 resolveArgument其部分代码如下逻辑也是把所有参数解析器拿出来溜溜看看哪个解析器的 supportsParameter 方法满足。 public Object resolveArgument(MethodParameter parameter, Nullable ModelAndViewContainer mavContainer,NativeWebRequest webRequest, Nullable WebDataBinderFactory binderFactory) throws Exception {HandlerMethodArgumentResolver resolver getArgumentResolver(parameter);return resolver.resolveArgument(parameter, mavContainer, webRequest, binderFactory); }public HandlerMethodArgumentResolver getArgumentResolver(MethodParameter parameter) {HandlerMethodArgumentResolver result this.argumentResolverCache.get(parameter);if (result null) {for (HandlerMethodArgumentResolver resolver : this.argumentResolvers) {if (resolver.supportsParameter(parameter)) {result resolver;this.argumentResolverCache.put(parameter, result);break;}}}return result; }不出意外满足的是 RequestResponseBodyMethodProcessor运行截图如下从27个参数解析器中选中了这个。 流程重新梳理一下 遍历所有参数列表依次利用 supportsParameter 方法判断是否有解析器是否满足再进行下面的一系列判定逻辑最终可以找到 RequestResponseBodyMethodProcessor 这一解析器是符合的紧接着把参数解析器放到 argumentResolverCache 缓存中 Override public boolean supportsParameter(MethodParameter parameter) {return parameter.hasParameterAnnotation(RequestBody.class); }Override public boolean supportsReturnType(MethodParameter returnType) {return (AnnotatedElementUtils.hasAnnotation(returnType.getContainingClass(), ResponseBody.class) ||returnType.hasMethodAnnotation(ResponseBody.class)); }最终调用RequestResponseBodyMethodProcessor 的 resolveArgument 进行参数解析 Tips这里其实又是一个适配器的套路适配器模式Spring为我们提供了多种场景的支持。 【RequestParam 注解】 如果接口的参数使用 RequestParam 注解那么这里满足的是 RequestParamMethodArgumentResolver 运行截图如下当然它也是第一顺位。 值得一提如果没找到合适的参数处理器那么最后还是会用 RequestParamMethodArgumentResolver 兜底此时后话暂且不提。 Step6、RequestResponseBodyMethodProcessor#readWithMessageConverters 如果使用 RequestBody 注解的resolver一般为 RequestResponseBodyMethodProcessor从下面它的父类可以看出来它既是一个参数解析器也是一个返回值处理器对应两个注解的处理。 public class RequestResponseBodyMethodProcessor extends AbstractMessageConverterMethodProcessor { }public abstract class AbstractMessageConverterMethodProcessor extends AbstractMessageConverterMethodArgumentResolverimplements HandlerMethodReturnValueHandler { }protected T Object readWithMessageConverters(NativeWebRequest webRequest, MethodParameter methodParam,Type paramType) throws IOException, HttpMediaTypeNotSupportedException {HttpServletRequest servletRequest webRequest.getNativeRequest(HttpServletRequest.class);HttpInputMessage inputMessage new ServletServerHttpRequest(servletRequest);// 得到注解RequestBody ann methodParam.getParameterAnnotation(RequestBody.class);// 一般是trueif (!ann.required()) {InputStream inputStream inputMessage.getBody();if (inputStream null) {return null;}else if (inputStream.markSupported()) {inputStream.mark(1);if (inputStream.read() -1) {return null;}inputStream.reset();}else {final PushbackInputStream pushbackInputStream new PushbackInputStream(inputStream);int b pushbackInputStream.read();if (b -1) {return null;}else {pushbackInputStream.unread(b);}inputMessage new ServletServerHttpRequest(servletRequest) {Overridepublic InputStream getBody() {// Form POST should not get herereturn pushbackInputStream;}};}}//一般会走到这里return super.readWithMessageConverters(inputMessage, methodParam, paramType); }继续走到AbstractMessageConverterMethodArgumentResolver#readWithMessageConverters代码如下 protected T Object readWithMessageConverters(HttpInputMessage inputMessage,MethodParameter methodParam, Type targetType) throws IOException, HttpMediaTypeNotSupportedException { ... 省略...for (HttpMessageConverter? converter : this.messageConverters) {if (converter instanceof GenericHttpMessageConverter) {GenericHttpMessageConverter genericConverter (GenericHttpMessageConverter) converter;if (genericConverter.canRead(targetType, contextClass, contentType)) {if (logger.isDebugEnabled()) {logger.debug(Reading [ targetType ] as \ contentType \ using [ converter ]);}//json数据转为对象return genericConverter.read(targetType, contextClass, inputMessage);}} ...省略...throw new HttpMediaTypeNotSupportedException(contentType, this.allSupportedMediaTypes); } 这里的messageConverters变量的值就是我们前面注册的MappingJackson2HttpMessageConverter如下图所示。 //最后调用MappingJackson2HttpMessageConverter#read //再走到下面这个方法 private Object readJavaType(JavaType javaType, HttpInputMessage inputMessage) {try {// 是Jackson的API请求的InputStream流转为对象// 如果json数据是空的此处会抛出 Could not read JSON: No content to map due to end-of-inputreturn this.objectMapper.readValue(inputMessage.getBody(), javaType);}catch (IOException ex) {throw new HttpMessageNotReadableException(Could not read JSON: ex.getMessage(), ex);} } Step7、RequestResponseBodyMethodProcessor#readWithMessageConverters 上面取到了实体对象了如下图所示 接着往前追溯 RequestResponseBodyMethodProcessor#resolveArgument InvocableHandlerMethod#getMethodArgumentValues InvocableHandlerMethod#invokeForRequest InvocableHandlerMethod#doInvoke 开始真实调用逻辑了传递了解析后的参数了再下来就是真实的控制层请求。 请求完毕之后又回到DispatcherServlet#doDispatch再来就是返回值的处理了。 请求分析复盘 整个流程梳理精简版 Tips上述分析流程精简一下可以得出如下结论。 1、总入口 DispatcherServlet最底层其实是 HttpServlet#service 2、根据请求URL找到处理方法MethodDispatcherServlet#getHandler 3、参数处理HandlerMethodArgumentResolverRequestResponseBodyMethodProcessor 4、执行原方法逻辑invoke 5、返回值处理HandlerMethodReturnValueHandlerRequestResponseBodyMethodProcessor 【补充上述流程分析】 1、HandlerMapping 阶段匹配到一个HandlerMapping通过Url找到某个controller的某个方法。返回HandlerExecutionChain 对象 2、根据HandlerMethod匹配到某个HandlerAdapter也就是我们的RequestMappingHandlerAdapter 3、this.argumentResolvers.supportsParameter(parameter)匹配参数处理器这里会匹配到RequestResponseBodyMethodProcessor 4、从messageConverters集合中匹配出参数转换器这里是MappingJackson2HttpMessageConverter。调用Jackson API转换成对象 5、得到参数后利用反射执行某个controller中某个方法 从这里我们可以看出Spring框架是相当灵活的适配器模式是被其发挥得淋漓尽致。支持我们自定义HandlerMapping、HandlerAdapter、messageConverters等等以适应更多的应用场景。 Tips虽然可以注册多个 argumentResolver 和 messageConverters但最终只会选择一个合适的执行。 【补充RequestBody 介绍】 RequestBody 注解是 Spring MVC 中的一个注解用于指示控制器方法参数应该绑定到 HTTP 请求的主体body部分。当客户端向服务器发送 POST 或 PUT 请求时请求的数据通常包含在请求主体中而不是在 URL 参数中。RequestBody 注解告诉 Spring MVC 框架将请求主体中的数据反序列化为指定的 Java 对象并将其作为方法的参数传递给控制器方法。 具体来说RequestBody 注解的作用包括以下几个方面 反序列化请求主体 当客户端发送一个包含 JSON、XML 等格式的数据主体的 POST 或 PUT 请求时Spring MVC 框架将请求主体中的数据反序列化为指定的 Java 对象。这个过程通常使用 Jackson、JAXB 等库来完成将请求主体中的数据转换为相应的 Java 对象。 绑定到方法参数 反序列化后的 Java 对象将作为 RequestBody 注解标注的方法参数的值传递给控制器方法。通过使用 RequestBody 注解你可以直接将请求主体中的数据映射到方法参数而不必手动解析请求主体或处理输入流。 处理多种数据格式 RequestBody 注解不仅可以处理 JSON 格式的数据还可以处理 XML、表单数据等多种格式的数据。Spring MVC 框架会根据请求的 Content-Type 头部来确定请求主体的数据格式并使用相应的消息转换器MessageConverter来进行反序列化。 综上所述RequestBody 注解在 Spring MVC 中的作用是将请求主体中的数据反序列化为指定的 Java 对象并绑定到控制器方法的参数上使得控制器方法能够直接处理请求主体中的数据。 【补充关于 HandlerMapping 和 HandlerAdapter 的初始化】 protected void initStrategies(ApplicationContext context) {...省略...//初始化HandlerMappingsinitHandlerMappings(context);//初始化HandlerAdaptersinitHandlerAdapters(context);...省略... }HandlerMapping和HandlerAdapter是可以多个的Spring默认会注册几个HandlerMapping如BeanNameUrlHandlerMapping、SimpleUrlHandlerMapping有请求来的时候去匹配到合适的那个。 在Spring MVC时代我们通常会显式去注册一个HandlerMapping和HandlerAdapter分别是RequestMappingHandlerMapping和RequestMappingHandlerAdapter。 当然要使用MappingJackson2HttpMessageConverter转换器还需要jackson-databind、jackson-core、jackson-mapper-lgpl、jackson-mapper-asl、jackson-core-lgpl、jackson-core-asl这些Jar包。 HandlerAdapter 和 HandlerMapping 也是类似的逻辑一样是支持多个默认注册HttpRequestHandlerAdapter、SimpleControllerHandlerAdapter。 doDispatch部分源码 protected void doDispatch(HttpServletRequest request, HttpServletResponse response) throws Exception {HttpServletRequest processedRequest request;HandlerExecutionChain mappedHandler null;boolean multipartRequestParsed false;WebAsyncManager asyncManager WebAsyncUtils.getAsyncManager(request);try {ModelAndView mv null;Exception dispatchException null;try {//检测是否有上传的头信息processedRequest checkMultipart(request);multipartRequestParsed (processedRequest ! request);// Determine handler for the current request.//找出处理这个请求的handler链mappedHandler getHandler(processedRequest, false);if (mappedHandler null || mappedHandler.getHandler() null) {noHandlerFound(processedRequest, response);return;}// Determine handler adapter for the current request.//根据handler得到adapterHandlerAdapter ha getHandlerAdapter(mappedHandler.getHandler());// Process last-modified header, if supported by the handler.String method request.getMethod();boolean isGet GET.equals(method);if (isGet || HEAD.equals(method)) {//RequestMappingHandlerAdapter#getLastModified返回-1long lastModified ha.getLastModified(request, mappedHandler.getHandler());if (logger.isDebugEnabled()) {logger.debug(Last-Modified value for [ getRequestUri(request) ] is: lastModified);}// 检测是否未改变 并且 是get请求if (new ServletWebRequest(request, response).checkNotModified(lastModified) isGet) {return;}}//拦截器if (!mappedHandler.applyPreHandle(processedRequest, response)) { //不为true则returnreturn;}//如果是注解方式使用的是RequestMappingHandlerAdapter然后到父类AbstractHandlerMethodAdapter#handle方法// Actually invoke the handler.mv ha.handle(processedRequest, response, mappedHandler.getHandler());if (asyncManager.isConcurrentHandlingStarted()) {return;}//mv不为null并且view不存在则应用默认的viewNameapplyDefaultViewName(request, mv);//主要执行拦截器postHandle方法mappedHandler.applyPostHandle(processedRequest, response, mv);}catch (Exception ex) {dispatchException ex;}//处理处理程序选择和处理程序调用的结果即要解析为ModelAndView或异常。processDispatchResult(processedRequest, response, mappedHandler, mv, dispatchException);}catch (Exception ex) {//主要是发生异常时执行拦截器afterCompletion方法triggerAfterCompletion(processedRequest, response, mappedHandler, ex);}catch (Error err) {triggerAfterCompletionWithError(processedRequest, response, mappedHandler, err);}finally {if (asyncManager.isConcurrentHandlingStarted()) {// Instead of postHandle and afterCompletionif (mappedHandler ! null) {mappedHandler.applyAfterConcurrentHandlingStarted(processedRequest, response);}}else {// Clean up any resources used by a multipart request.if (multipartRequestParsed) {cleanupMultipart(processedRequest);}}} }总结陈词 此篇文章介绍了SpringMVC 请求流程的源码分析仅供参考。 无论是 handlerAdapters 还是 argumentResolvers或者其他基本几个用法都类似。 预先加载List遍历List判断是否满足适配器思想缓存思想。。。 篇幅所限主要介绍了一个具体请求的流程后续系列文章会针对其中重要步骤继续展开介绍同时添加实战说明。 后续会逐步分享企业实际开发中的实战经验有需要交流的可以联系博主。
文章转载自:
http://www.morning.bpmtl.cn.gov.cn.bpmtl.cn
http://www.morning.stsnf.cn.gov.cn.stsnf.cn
http://www.morning.swlwf.cn.gov.cn.swlwf.cn
http://www.morning.wxrbl.cn.gov.cn.wxrbl.cn
http://www.morning.bnwlh.cn.gov.cn.bnwlh.cn
http://www.morning.zcqtr.cn.gov.cn.zcqtr.cn
http://www.morning.jpgfq.cn.gov.cn.jpgfq.cn
http://www.morning.jtsdk.cn.gov.cn.jtsdk.cn
http://www.morning.yjfzk.cn.gov.cn.yjfzk.cn
http://www.morning.c7495.cn.gov.cn.c7495.cn
http://www.morning.sqgqh.cn.gov.cn.sqgqh.cn
http://www.morning.yysqz.cn.gov.cn.yysqz.cn
http://www.morning.tzrmp.cn.gov.cn.tzrmp.cn
http://www.morning.knqzd.cn.gov.cn.knqzd.cn
http://www.morning.zdwjg.cn.gov.cn.zdwjg.cn
http://www.morning.kybjr.cn.gov.cn.kybjr.cn
http://www.morning.xwrhk.cn.gov.cn.xwrhk.cn
http://www.morning.wdlg.cn.gov.cn.wdlg.cn
http://www.morning.dhyqg.cn.gov.cn.dhyqg.cn
http://www.morning.lkkkf.cn.gov.cn.lkkkf.cn
http://www.morning.kfstq.cn.gov.cn.kfstq.cn
http://www.morning.kgphd.cn.gov.cn.kgphd.cn
http://www.morning.rjcqb.cn.gov.cn.rjcqb.cn
http://www.morning.rzbgn.cn.gov.cn.rzbgn.cn
http://www.morning.ywpwg.cn.gov.cn.ywpwg.cn
http://www.morning.kwxr.cn.gov.cn.kwxr.cn
http://www.morning.mcfjq.cn.gov.cn.mcfjq.cn
http://www.morning.xlmpj.cn.gov.cn.xlmpj.cn
http://www.morning.fblkr.cn.gov.cn.fblkr.cn
http://www.morning.hcsnk.cn.gov.cn.hcsnk.cn
http://www.morning.rgpy.cn.gov.cn.rgpy.cn
http://www.morning.jwxnr.cn.gov.cn.jwxnr.cn
http://www.morning.tgmfg.cn.gov.cn.tgmfg.cn
http://www.morning.jzkqg.cn.gov.cn.jzkqg.cn
http://www.morning.bangaw.cn.gov.cn.bangaw.cn
http://www.morning.jyyw.cn.gov.cn.jyyw.cn
http://www.morning.jwsrp.cn.gov.cn.jwsrp.cn
http://www.morning.jftl.cn.gov.cn.jftl.cn
http://www.morning.grnhb.cn.gov.cn.grnhb.cn
http://www.morning.rahllp.com.gov.cn.rahllp.com
http://www.morning.sdktr.com.gov.cn.sdktr.com
http://www.morning.madamli.com.gov.cn.madamli.com
http://www.morning.tgydf.cn.gov.cn.tgydf.cn
http://www.morning.zfqr.cn.gov.cn.zfqr.cn
http://www.morning.xsrnr.cn.gov.cn.xsrnr.cn
http://www.morning.jmmzt.cn.gov.cn.jmmzt.cn
http://www.morning.gthc.cn.gov.cn.gthc.cn
http://www.morning.rgrys.cn.gov.cn.rgrys.cn
http://www.morning.trrhj.cn.gov.cn.trrhj.cn
http://www.morning.cmzgt.cn.gov.cn.cmzgt.cn
http://www.morning.ycmpk.cn.gov.cn.ycmpk.cn
http://www.morning.pcgmw.cn.gov.cn.pcgmw.cn
http://www.morning.hxhrg.cn.gov.cn.hxhrg.cn
http://www.morning.qnrpj.cn.gov.cn.qnrpj.cn
http://www.morning.stbfy.cn.gov.cn.stbfy.cn
http://www.morning.ybgpk.cn.gov.cn.ybgpk.cn
http://www.morning.kbgzj.cn.gov.cn.kbgzj.cn
http://www.morning.ybqlb.cn.gov.cn.ybqlb.cn
http://www.morning.ljygq.cn.gov.cn.ljygq.cn
http://www.morning.tzkrh.cn.gov.cn.tzkrh.cn
http://www.morning.fhtbk.cn.gov.cn.fhtbk.cn
http://www.morning.rgsnk.cn.gov.cn.rgsnk.cn
http://www.morning.jstggt.cn.gov.cn.jstggt.cn
http://www.morning.hcqpc.cn.gov.cn.hcqpc.cn
http://www.morning.bhdtx.cn.gov.cn.bhdtx.cn
http://www.morning.cwfkm.cn.gov.cn.cwfkm.cn
http://www.morning.tnbas.com.gov.cn.tnbas.com
http://www.morning.nktxr.cn.gov.cn.nktxr.cn
http://www.morning.ykklw.cn.gov.cn.ykklw.cn
http://www.morning.yzsdp.cn.gov.cn.yzsdp.cn
http://www.morning.xkyst.cn.gov.cn.xkyst.cn
http://www.morning.gxklx.cn.gov.cn.gxklx.cn
http://www.morning.lbpqk.cn.gov.cn.lbpqk.cn
http://www.morning.tmnyj.cn.gov.cn.tmnyj.cn
http://www.morning.fqyqm.cn.gov.cn.fqyqm.cn
http://www.morning.lynmt.cn.gov.cn.lynmt.cn
http://www.morning.bmtyn.cn.gov.cn.bmtyn.cn
http://www.morning.ljxps.cn.gov.cn.ljxps.cn
http://www.morning.gczqt.cn.gov.cn.gczqt.cn
http://www.morning.ncfky.cn.gov.cn.ncfky.cn
http://www.tj-hxxt.cn/news/272771.html

相关文章:

  • asp网站经常 响应简述网站制作的一般流程
  • 专门做水产海鲜的网站吗创建商城
  • 厦门同安区建设局网站百度收录自适应网站
  • 什么是网站推广优化大连百度关键词排名
  • 魔方网站建设天津做网站的公司有哪家
  • 神华集团 两学一做 网站粉丝帮女流做的网站
  • 个人博客网站怎么注册网站右侧信息跟随左侧菜单栏变化
  • 网站和主机有什么不同太原网站建设优化
  • 常州网站关键词优化软件网页设计欣赏
  • 建设部网站官网四库一平台网站制作相关知识
  • 济南网站托管论文收录网站
  • 怎样推广产品优化大师最新版下载
  • 汕头网站推广seo网址之家123上网主页
  • 会计公司网站模板wordpress 产品筛选
  • 专业建站公司推荐dw网页制作入门教程
  • 建立用模板建立网站上海公司买车需要什么条件
  • 网站404页面制作佛山市城市建设工程有限公司
  • 电子商务网站建设与维护书anmpp wordpress
  • 公司推广咨询百度竞价关键词优化
  • 怎么做网站流量赚钱郑州网站建设制作公司
  • 省厅建设信息网网站黑色系 网站
  • 羊肉口报关做网站网站建设包含项目
  • 厦门免费网站建设珠海网站建设费用
  • 濮阳市网站建设电商网站建设实验原理
  • 工信部网站备案查询 验证码宁波建设网站公众号关注
  • 蓝色网站模版最新公司注册流程
  • 视频网站开发公司小型网站开发教程
  • 南昌哪里做网站比较好连城住房和城乡建设局门户网站
  • 老会计手把手教做帐官方网站百度收录哪些平台比较好
  • 微信的官方网站怎么做卓越职业院校建设专题网站