Web学习笔记 - 第014天

异步处理

在servlet中service方法中

        // 获得异步操作的上下文环境
        AsyncContext asyncContext = req.startAsync();
        // 设置异步操作超时时间
        asyncContext.setTimeout(5000);
        // new HeavyWorkHandler(asyncContext).handle();
        // 添加异步监听器
        asyncContext.addListener(new AsyncListener() {
            
            @Override
            public void onTimeout(AsyncEvent arg0) throws IOException {         
            }
            
            @Override
            public void onStartAsync(AsyncEvent arg0) throws IOException {          
            }
            
            @Override
            public void onError(AsyncEvent arg0) throws IOException {       
            }
            
            @Override
            public void onComplete(AsyncEvent arg0) throws IOException {    
            }
        });

        // 启动异步上下文进行异步操作
        asyncContext.start(() -> {
            ServletRequest request = asyncContext.getRequest();
            ServletResponse response = asyncContext.getResponse();
            // 执行耗时间的操作
            // 耗时间操作完成之后要么结束异步上下文
            asyncContext.complete();
            // 要么将请求派发到某个页面上
            asyncContext.dispatch("page.jsp");
        });

好处:
将耗时间的操作放在异步上下文中执行主要的好处是:
不影响Tomcat单位时间接入的用户请求的数量。如果没有异步环境Tomcat默认的200个线程用完了之后,其他的请求就必须排队等待Tomcat接入,这样的话越靠后的请求等待时间越长,甚至有可能半分钟时间都无法正常接入

创建一个类来处理异步操作
public class HeavyWorkHandler {
    private AsyncContext context;
    
    public HeavyWorkHandler (AsyncContext context) {
        this.context = context;
    }
    
    public void handle() {
        ServletRequest request = context.getRequest();
        ServletResponse response = context.getResponse();
        
        context.start(new Runnable() {
            
            @Override
            public void run() {
                
            }
        });
    }
}

安全性

在tomcat-user.xml配置
    <role rolename="authorizedUser" />
    <role rolename="admin" />
    <role rolename="manager" />
    <role rolename="emp" />
    <user username="jack" password="123456" roles="admin,manager" />
在web.xml配置
  <!-- 配置安全性约束 -->
  <security-constraint>
    <!-- 指定需要安全约束的资源 -->
    <web-resource-collection>
        <web-resource-name>protected</web-resource-name>
        <url-pattern>/*</url-pattern>
    </web-resource-collection>
    <auth-constraint>
        <role-name>manager</role-name>
    </auth-constraint>
  </security-constraint>
  
  <login-config>
    <auth-method>DIGEST</auth-method>
    <realm-name>protected</realm-name>
  </login-config>

AA

AA - Authentication / Authorization

  • What you konw?
  • What you have?
  • Whom you are?

客户端证书验证

SSL
创建密钥 keytool -genkey -alias tomcat -keyalg RSA
keytool - certreq -alias tomcat -file tomcat.csr
keytool -importcert -alias tomcat -file tomcat.cer

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 134,854评论 18 139
  • 服务器https配置 配置https操作说明文档 1、查看服务器环境配置(tomcat和apache合并使用) 2...
    南京杨小兵阅读 8,902评论 0 9
  • VO Value Object / View Object 专门为视图定制的模型如: DTO Data Trans...
    迷茫o阅读 224评论 0 0
  • 丢了气球的小女孩 遗失童年做过的梦 木板秋千晃荡在时光的两端 无人陪伴 星星是眼里的闪烁 棉花糖是时光的过客 你迟...
    云曦曦阅读 305评论 2 2
  • 今天雨宝11个月4天终于学会爬了,平时爷爷奶奶担心肮脏一直抱着很少让她爬!所以我家雨宝十一个月,还不太敢地上爬,只...
    牛小丫53阅读 226评论 0 1