亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

5個(gè)Java API使用技巧

 更新時(shí)間:2017年10月18日 10:05:52   作者:CSDN鄧帥  
這篇文章主要為大家詳細(xì)介紹了Java API安全和性能方面的簡(jiǎn)單易用技巧,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下

本文介紹了一些關(guān)于Java API安全和性能方面的簡(jiǎn)單易用的技巧,其中包括保證API Key安全和開發(fā)Web Service方面中在框架方面選擇的一些建議。

程序員都喜歡使用API!例如為app應(yīng)用構(gòu)建API或作為微服務(wù)架構(gòu)體系的一部分。當(dāng)然,使用API的前提是能讓你的工作變得更輕松。為了簡(jiǎn)化開發(fā)和提高工作效率所作出的努力,有時(shí)也意味著需要尋找新的類庫(kù)或者過程(或者減少過程)。對(duì)于很多開發(fā)團(tuán)隊(duì)來(lái)說(shuō),對(duì)于其APP和API進(jìn)行管理認(rèn)證和訪問控制要耗費(fèi)很多的時(shí)間,因此我們需想分享一些技巧,它們能節(jié)約你的時(shí)間,減少代碼編寫量,并能讓你的應(yīng)用更加安全和易于維護(hù)。  

先介紹下本文提及的背景知識(shí):Okta是一個(gè)基于REST、JSON API構(gòu)建的Java應(yīng)用,使用Spring框架構(gòu)建。我們公司的應(yīng)用,是保存用戶的身份憑證和其他公司的敏感數(shù)據(jù),所以對(duì)我們來(lái)說(shuō),安全是最重要的。因此,我對(duì)這些技巧的第一個(gè)要求是,它們能幫助令到你的Java應(yīng)用更安全。

這些建議應(yīng)該是任何類型的Java應(yīng)用都是通用的。它們會(huì)幫助你更快地編寫代碼,但代碼量更少了,同時(shí)又更安全:這真的是三贏的結(jié)果! 

1. 不要自己去實(shí)現(xiàn)安全框架

說(shuō)真的,不要嘗試自己去實(shí)現(xiàn)安全方面的代碼,這太難了。

幾乎每個(gè)人都知道避免去實(shí)現(xiàn)加密等算法。同樣道理,你的應(yīng)用的安全棧的其余部分也是一樣,可能需要花費(fèi)很大,得到的風(fēng)險(xiǎn)也很大。你很可能會(huì)犯一些錯(cuò)誤。自1999年以來(lái),已經(jīng)有89373個(gè)CVE(公共漏洞和暴露)發(fā)布了。而其中公開的大部分的發(fā)現(xiàn)者都是那些非常聰明的人。

你可能認(rèn)為處理一個(gè)簡(jiǎn)單的用例(例如驗(yàn)證用戶的密碼)是很簡(jiǎn)單的事情——你所做的一切只是比較一對(duì)字符串。這樣想就錯(cuò)了。你需要驗(yàn)證密碼的哈希值,審核嘗試登錄的次數(shù),減少針對(duì)字典的攻擊,這只是冰山一角。你最好的選擇是使用現(xiàn)有的成熟的庫(kù)或框架,例如Apache的Shiro或者SpringSecurity,讓這些框架去處理各類復(fù)雜的安全問題。

2. Use TLS, Always! 永遠(yuǎn)使用TLS!  

現(xiàn)在已經(jīng)是2017年了,所有的網(wǎng)站都應(yīng)該使用HTTPS了,甚至是公司的內(nèi)網(wǎng)。Let's encrypt讓HTTPS變得輕松和簡(jiǎn)單,這意味著你能不再使用不安全的自簽密鑰了!你甚至可以在本地設(shè)置帶證書認(rèn)證的Tomcat或者Nginx實(shí)例。

能讓你的應(yīng)用需要TLS(HTTPS/SSL)只需要簡(jiǎn)單的一行代碼,所有人都應(yīng)該這樣做!如果使用Apache Shiro框架,只需要設(shè)置屬性:

[urls]/** = ssl

如果使用Spring Security,,只需要在設(shè)置HttpSecurity時(shí),簡(jiǎn)單調(diào)用一個(gè)方法即可。

http.requiresChannel()
.anyRequest().requiresSecure();

在Spring Boot中,僅需設(shè)置一些屬性,如下:

server.port=8443
server.ssl.key-store=classpath:keystore.jks
server.ssl.key-store-password=secret
server.ssl.key-password=another-secret

3. 使用Spring Boot創(chuàng)建Web Service

Spring Boot是Spring平臺(tái)的一個(gè)簡(jiǎn)化,能讓編寫Spring應(yīng)用變得很簡(jiǎn)單,例如能用很少的代碼,編寫《app應(yīng)用中考慮的12個(gè)因素》一文中提到的觀點(diǎn)。如果你還在使用建War包的方式編碼,那么Spring Boot值得你去學(xué)習(xí)。使用Spring Boot可以復(fù)雜的、不同類型的應(yīng)用,例如可以使用簡(jiǎn)單的注解(@EnableResourceServer)就搭建一個(gè)OAuth資源服務(wù)器,或者通過簡(jiǎn)單的屬性改變其端口:

server.port = 8090

如果不喜歡使用SpringBoot,那么可以使用Dropwizard去搭建JAX-RS技術(shù)棧。

4. 監(jiān)視應(yīng)用和性能指標(biāo)

如果無(wú)任何數(shù)據(jù)的情況下是很難發(fā)現(xiàn)程序的錯(cuò)誤的。Spring Boot通過使用Actuator,能讓收集指標(biāo)數(shù)據(jù)變得容易,只需要在應(yīng)用中增加一個(gè)依賴,如下:

<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-actuator</artifactId>
</dependency>`

然后就可以通過瀏覽器中,在訪問應(yīng)用地址后輸入/health 或者/metrics去檢查應(yīng)用的健康情況或者指標(biāo)。Dropwizard框架通過/healthcheck和/metrics實(shí)現(xiàn)同樣的功能。

下面是Spring Boot應(yīng)用通過/metrics 輸出的結(jié)果:

  {
  "classes": 7704,
  "classes.loaded": 7704,
  "classes.unloaded": 0,
  "counter.status.200.metrics": 1,
  "gauge.response.metrics": 99.0,
  "gc.ps_marksweep.count": 2,
  "gc.ps_marksweep.time": 272,
  "gc.ps_scavenge.count": 8,
  "gc.ps_scavenge.time": 136,
  "heap": 3728384,
  "heap.committed": 470016,
  "heap.init": 262144,
  "heap.used": 207793,
  "httpsessions.active": 0,
  "httpsessions.max": -1,
  "instance.uptime": 25020,
  "mem": 529086,
  "mem.free": 262222,
  "nonheap": 0,
  "nonheap.committed": 60608,
  "nonheap.init": 2496,
  "nonheap.used": 59067,
  "processors": 8,
  "systemload.average": 5.56103515625,
  "threads": 24,
  "threads.daemon": 22,
  "threads.peak": 28,
  "threads.totalStarted": 32,
  "uptime": 37182}

5. 保護(hù)敏感信息

人們都認(rèn)為API密鑰是不安全的,這是事實(shí)。密鑰通過電子郵件發(fā)送或源代碼管理系統(tǒng)控制。也許這是它們看起來(lái)比密碼更不安全的原因,但它們也一樣敏感。如果需要將API密鑰存儲(chǔ)在文件中,請(qǐng)確保授予文件有限的訪問權(quán)限。例如,我們建議在私人目錄中存放Okta的YAML文件并且賦予文件所有者只讀權(quán)限。

$ chmod u=r,go-rwx ~/.okta/okta.yaml

如果你正為使用你的APP的用戶創(chuàng)建API,記得提醒他們,如果無(wú)設(shè)置好權(quán)限的話,.SSH的忽文件是放在你的~/.ssh目錄下,如果無(wú)設(shè)置好權(quán)限的話。GitHub 把它們放在“危險(xiǎn)區(qū)域”,以提醒用戶,這是十分有用的。

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • RabbitMQ消息拒絕如何解決

    RabbitMQ消息拒絕如何解決

    這篇文章主要介紹了RabbitMQ消息拒絕如何解決問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2024-01-01
  • SpringBoot中的Mybatis依賴問題

    SpringBoot中的Mybatis依賴問題

    這篇文章主要介紹了SpringBoot中的Mybatis依賴問題,包括pom導(dǎo)入依賴和相關(guān)實(shí)例代碼講解,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2022-04-04
  • SpringBoot創(chuàng)建maven多模塊項(xiàng)目實(shí)戰(zhàn)代碼

    SpringBoot創(chuàng)建maven多模塊項(xiàng)目實(shí)戰(zhàn)代碼

    本篇文章主要介紹了SpringBoot創(chuàng)建maven多模塊項(xiàng)目實(shí)戰(zhàn)代碼,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來(lái)看看吧
    2017-09-09
  • Java實(shí)現(xiàn)自動(dòng)獲取法定節(jié)假日詳細(xì)代碼

    Java實(shí)現(xiàn)自動(dòng)獲取法定節(jié)假日詳細(xì)代碼

    這篇文章主要給大家介紹了關(guān)于Java實(shí)現(xiàn)自動(dòng)獲取法定節(jié)假日的相關(guān)資料,獲取并處理節(jié)假日數(shù)據(jù)是一個(gè)常見需求,特別是在需要安排任務(wù)調(diào)度、假期通知等功能的場(chǎng)景中,需要的朋友可以參考下
    2024-05-05
  • 詳解SpringBoot開發(fā)案例之整合定時(shí)任務(wù)(Scheduled)

    詳解SpringBoot開發(fā)案例之整合定時(shí)任務(wù)(Scheduled)

    本篇文章主要介紹了詳解SpringBoot開發(fā)案例之整合定時(shí)任務(wù)(Scheduled),具有一定的參考價(jià)值,有興趣的可以了解一下
    2017-07-07
  • spring如何動(dòng)態(tài)指定具體實(shí)現(xiàn)類

    spring如何動(dòng)態(tài)指定具體實(shí)現(xiàn)類

    這篇文章主要為大家詳細(xì)介紹了spring如何動(dòng)態(tài)指定具體實(shí)現(xiàn)類,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2016-10-10
  • Spring中@ControllerAdvice注解的用法解析

    Spring中@ControllerAdvice注解的用法解析

    這篇文章主要介紹了Spring中@ControllerAdvice注解的用法解析,顧名思義,@ControllerAdvice就是@Controller 的增強(qiáng)版,@ControllerAdvice主要用來(lái)處理全局?jǐn)?shù)據(jù),一般搭配@ExceptionHandler、@ModelAttribute以及@InitBinder使用,需要的朋友可以參考下
    2023-10-10
  • SpringBoot搭建Dubbo項(xiàng)目實(shí)現(xiàn)斐波那契第n項(xiàng)詳解

    SpringBoot搭建Dubbo項(xiàng)目實(shí)現(xiàn)斐波那契第n項(xiàng)詳解

    這篇文章主要講解了“SpringBoot+Dubbo怎么實(shí)現(xiàn)斐波那契第N項(xiàng)”,文中的講解內(nèi)容簡(jiǎn)單清晰,易于學(xué)習(xí)與理解,下面請(qǐng)大家跟著小編的思路慢慢深入,一起來(lái)研究和學(xué)習(xí)吧
    2022-06-06
  • SwiftUI中級(jí)List如何添加新內(nèi)容(2020年教程)

    SwiftUI中級(jí)List如何添加新內(nèi)容(2020年教程)

    這篇文章主要介紹了SwiftUI中級(jí)List如何添加新內(nèi)容,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2020-01-01
  • Java?SpringBoot整合shiro-spring-boot-starterqi項(xiàng)目報(bào)錯(cuò)解決

    Java?SpringBoot整合shiro-spring-boot-starterqi項(xiàng)目報(bào)錯(cuò)解決

    這篇文章主要介紹了Java?SpringBoot整合shiro-spring-boot-starterqi項(xiàng)目報(bào)錯(cuò)解決,文章圍繞主題展開詳細(xì)的內(nèi)容介紹,具有一定的參考一下
    2022-08-08

最新評(píng)論