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,993評論 19 139
  • 服務器https配置 配置https操作說明文檔 1、查看服務器環境配置(tomcat和apache合并使用) 2...
    南京楊小兵閱讀 8,942評論 0 9
  • VO Value Object / View Object 專門為視圖定制的模型如: DTO Data Trans...
    迷茫o閱讀 225評論 0 0
  • 丟了氣球的小女孩 遺失童年做過的夢 木板秋千晃蕩在時光的兩端 無人陪伴 星星是眼里的閃爍 棉花糖是時光的過客 你遲...
    云曦曦閱讀 305評論 2 2
  • 今天雨寶11個月4天終于學會爬了,平時爺爺奶奶擔心骯臟一直抱著很少讓她爬!所以我家雨寶十一個月,還不太敢地上爬,只...
    牛小丫53閱讀 227評論 0 1