《企业级ios应用开发实战》一第2章 iOS开发框架简介
第2章 iOS开发框架简介 本章首先介绍苹果操作系统iOS的起源、发展及构成,然后对iOS开发框架Cocoa Touch进行介绍。Cocoa Touch(或Cocoa)是多个开发框架的集合,由多个层级的子框架构成。最后介绍苹果开发工具包iOS SDK及开发环境的搭建。
自定义View系列教程00–推翻自己和过往,重学自定义View
自定义View系列教程01–常用工具介绍
自定义View系列教程02–onMeasure源码详尽分析
自定义View系列教程03–onLayout源码详尽分析
自定义View系列教程04–Draw源码分析及其实践
自定义View系列教程05–示例分析
自定义View系列教程06–详解View的Touch事件处理
自定义View系列教程07–详解ViewGroup分发Touch事件
自定义View系列教程08–滑动冲突的产生及其处理
探索Android软键盘的疑难杂症
深入探讨Android异步精髓Handler
详解Android主流框架不可或缺的基石
站在源码的肩膀上全解Scroller工作机制
Android多分辨率适配框架(1)— 核心基础
Android多分辨率适配框架(2)— 原理剖析
Android多分辨率适配框架(3)— 使用指南
SpringMVC的处理器拦截器类似于Servlet开发中的过滤器Filter,用于对处理器进行预处理和后处理。在此,以示例的方式讲解拦截器的处理。
在该示例中我们定义两个拦截器,代码如下。
第一个拦截器:
/**
* @author 原创作者:谷哥的小弟
* @blog 博客地址:http://blog.csdn.net/lfdfhl
* @time 创建时间:2017年8月1日 上午9:28:26
* @info 描述信息:SpringMVC拦截器
*/
package cn.com.interceptor;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import org.springframework.web.servlet.HandlerInterceptor;
import org.springframework.web.servlet.ModelAndView;
public class Interceptor1 implements HandlerInterceptor{
public boolean preHandle(HttpServletRequest arg0, HttpServletResponse arg1,Object arg2) throws Exception {
System.out.println("第一个拦截器Interceptor的preHandle()方法");
return true;
}
public void postHandle(HttpServletRequest arg0, HttpServletResponse arg1,Object arg2, ModelAndView arg3) throws Exception {
System.out.println("第一个拦截器Interceptor的postHandle()方法");
}
public void afterCompletion(HttpServletRequest arg0,HttpServletResponse arg1, Object arg2, Exception arg3)throws Exception {
System.out.println("第一个拦截器Interceptor的afterCompletion()方法");
}
}
第二个拦截器:
/**
* @author 原创作者:谷哥的小弟
* @blog 博客地址:http://blog.csdn.net/lfdfhl
* @time 创建时间:2017年8月1日 上午9:28:26
* @info 描述信息:SpringMVC拦截器
*/
package cn.com.interceptor;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import org.springframework.web.servlet.HandlerInterceptor;
import org.springframework.web.servlet.ModelAndView;
public class Interceptor2 implements HandlerInterceptor{
public boolean preHandle(HttpServletRequest arg0, HttpServletResponse arg1,Object arg2) throws Exception {
System.out.println("第二个拦截器Interceptor的preHandle()方法");
return true;
}
public void postHandle(HttpServletRequest arg0, HttpServletResponse arg1,Object arg2, ModelAndView arg3) throws Exception {
System.out.println("第二个拦截器Interceptor的postHandle()方法");
}
public void afterCompletion(HttpServletRequest arg0,HttpServletResponse arg1, Object arg2, Exception arg3)throws Exception {
System.out.println("第二个拦截器Interceptor的afterCompletion()方法");
}
}
Interceptor需要实现HandlerInterceptor接口,并覆写里面的三个方法。
preHandle( ): 该方法将在处理器被调用前执行。SpringMVC 中的Interceptor 是链式的调用的,在一个应用中可同时存在多个Interceptor ;每个Interceptor的调用会依据其声明顺序依次执行,而且最先执行的都是Interceptor 中的preHandle( )方法,故可在该方法中进行一些前置初始化操作或预处理,也常在该方法中进行一些判断来决定请求是否要继续进行下去。该方法返回值为false 时,表示拦截请求即后续的Interceptor 和Controller 都不会再执行;当方法的返回值为true 时就会继续调用下一个Interceptor 的preHandle( );假若已经是最后一个Interceptor就会调用当前请求的Controller
postHandle( ): preHandle()的返回值为true 时才会被调用到该方法,这是一个前提条件。假若满足这个前提,那么该方法会在处理器被执行但在DispatcherServlet 进行视图返回渲染之前被调用;所以我们可以在这个方法中对ModelAndView进行相关操作。请注意:postHandle( )被调用的顺序跟preHandle( )是相反的,即先声明的Interceptor的postHandle( )反而会后执行
afterCompletion( ): preHandle()的返回值为true 时才会被调用到该方法,这是一个前提条件。顾名思义,该方法将在处理器被调用结束之后(即DispatcherServlet 渲染了对应的视图之后)执行。该方法的主要用于资源清理。
<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xmlns:mvc="http://www.springframework.org/schema/mvc"
xmlns:context="http://www.springframework.org/schema/context"
xmlns:aop="http://www.springframework.org/schema/aop"
xmlns:tx="http://www.springframework.org/schema/tx"
xsi:schemaLocation="http://www.springframework.org/schema/beans
http://www.springframework.org/schema/beans/spring-beans-3.2.xsd
http://www.springframework.org/schema/mvc
http://www.springframework.org/schema/mvc/spring-mvc-3.2.xsd
http://www.springframework.org/schema/context
http://www.springframework.org/schema/context/spring-context-3.2.xsd
http://www.springframework.org/schema/aop
http://www.springframework.org/schema/aop/spring-aop-3.2.xsd
http://www.springframework.org/schema/tx
http://www.springframework.org/schema/tx/spring-tx-3.2.xsd">
<!-- 配置自动扫描 -->
<context:component-scan base-package="cn.com"></context:component-scan>
<!-- 配置注解开发所需的处理器映射器-->
<bean class="org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerMapping"></bean>
<!-- 配置注解开发所需的处理器适配器 -->
<bean class="org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerAdapter"></bean>
<!-- 视图解析器 -->
<bean class="org.springframework.web.servlet.view.InternalResourceViewResolver">
<property name="prefix" value="/WEB-INF/jsps/"></property>
<property name="suffix" value=".jsp"></property>
</bean>
<!--配置拦截器 -->
<mvc:interceptors>
<mvc:interceptor>
<mvc:mapping path="/**"/>
<bean class="cn.com.interceptor.Interceptor1"></bean>
</mvc:interceptor>
<mvc:interceptor>
<mvc:mapping path="/**"/>
<bean class="cn.com.interceptor.Interceptor2"></bean>
</mvc:interceptor>
</mvc:interceptors>
</beans>
在代码第36行至46行配置之前编写的两个拦截器。
/**
* @author 原创作者:谷哥的小弟
* @blog 博客地址:http://blog.csdn.net/lfdfhl
* @time 创建时间:2017年8月1日 上午9:28:26
* @info 描述信息:SpringMVC拦截器
*/
package cn.com.controller;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestMapping;
@Controller
public class AnnotationController {
@RequestMapping("hello")
public String helloSpringMVCAnnotation(){
return "test";
}
}
在此实现一个非常简单的Controller
部署该示例后,在浏览器中输入:
http://localhost:8081/SpringMVC08/hello.do
输出日志如下:
第一个拦截器Interceptor的preHandle()方法
第二个拦截器Interceptor的preHandle()方法
第二个拦截器Interceptor的postHandle()方法
第一个拦截器Interceptor的postHandle()方法
第二个拦截器Interceptor的afterCompletion()方法
第一个拦截器Interceptor的afterCompletion()方法
微信关注我们
转载内容版权归作者及来源网站所有!
低调大师中文资讯倾力打造互联网数据资讯、行业资源、电子商务、移动互联网、网络营销平台。持续更新报道IT业界、互联网、市场资讯、驱动更新,是最及时权威的产业资讯及硬件资讯报道平台。
马里奥是站在游戏界顶峰的超人气多面角色。马里奥靠吃蘑菇成长,特征是大鼻子、头戴帽子、身穿背带裤,还留着胡子。与他的双胞胎兄弟路易基一起,长年担任任天堂的招牌角色。
为解决软件依赖安装时官方源访问速度慢的问题,腾讯云为一些软件搭建了缓存服务。您可以通过使用腾讯云软件源站来提升依赖包的安装速度。为了方便用户自由搭建服务架构,目前腾讯云软件源站支持公网访问和内网访问。
Nacos /nɑ:kəʊs/ 是 Dynamic Naming and Configuration Service 的首字母简称,一个易于构建 AI Agent 应用的动态服务发现、配置管理和AI智能体管理平台。Nacos 致力于帮助您发现、配置和管理微服务及AI智能体应用。Nacos 提供了一组简单易用的特性集,帮助您快速实现动态服务发现、服务配置、服务元数据、流量管理。Nacos 帮助您更敏捷和容易地构建、交付和管理微服务平台。
Rocky Linux(中文名:洛基)是由Gregory Kurtzer于2020年12月发起的企业级Linux发行版,作为CentOS稳定版停止维护后与RHEL(Red Hat Enterprise Linux)完全兼容的开源替代方案,由社区拥有并管理,支持x86_64、aarch64等架构。其通过重新编译RHEL源代码提供长期稳定性,采用模块化包装和SELinux安全架构,默认包含GNOME桌面环境及XFS文件系统,支持十年生命周期更新。