@RequestMapping,Rest API支持馅闽,跨域請求的設(shè)置方法

image.png

其中我們配置了JSONconvert轉(zhuǎn)換器 使我們的輸出和響應(yīng)支持我門的JSON格式(在Spring全局配置中設(shè)置)
假如我們用java想要做rest api 如果像之前那樣做是不是很麻煩
下面我們學(xué)習(xí)簡單的方法
image.png

其實(shí)只要一個@RestController 注解就夠了
下面我們先看下官網(wǎng) 打開網(wǎng)站搜索@REST就可以找到如下
image.png

說明了這個注解是個組合的注解 把@Responsebody和@Controller兩個注解組合了
下面我們在controllers包下面創(chuàng)建個UsesController控制器(用戶控制器)
目錄如下
image.png

在里面打入@RestController就可以了(說明是一個rest控制器)
并打入注解@RequestMapping("users")代表我們訪問的地址
接下來我們在entities包下面創(chuàng)建個UserInfo實(shí)體類
里面包含userid和username字段
生成構(gòu)造函數(shù) 和get set方法
如下
image.png

image.png

下面回到UsersController控制器
image.png

發(fā)布下代碼
用瀏覽器訪問localhost:8080/users/123
image.png

使用Spring MVC開發(fā)api還是很方便的
下面我們再來寫個用戶列表api
在UsersController中加入如下
image.png

重新發(fā)布下代碼
瀏覽器訪問localhost:8080/users/list
image.png

下面看下這段內(nèi)容
image.png

既然談到了rest api的開發(fā) 那么肯定存在跨域的問題
下面我隨便做個網(wǎng)站(是以php方式運(yùn)行的 端口是8999)
接下來創(chuàng)建個test.html
盤符目錄如下
image.png

使用標(biāo)準(zhǔn)的Fetch API對上面的url進(jìn)行ajax請求
下面看下test.html代碼
如果我們要使用前端的方式訪問后端的api
http://localhost:8080/users/123這個就是我們后端api地址
如果要做前后端分離網(wǎng)站 那么前端肯定是使用ajax方式對后端進(jìn)行請求 求情的時候可能會放入一些參數(shù)(這個時候可能就會碰到跨域的問題 因?yàn)槲覀兊木W(wǎng)站可能部署在不同的域名)
我在本地啟動了8999端口的網(wǎng)站 并放入test.html
下面我們寫段標(biāo)準(zhǔn)的ajax代碼(不使用jquery使用html5帶的fetch api)
顯示當(dāng)前用戶的具體值
代碼如下
image.png

然后我用瀏覽器訪問下這個頁面localhost:8999/test.html
結(jié)果如下
image.png

出現(xiàn)了CORS跨域請求錯誤
我們?nèi)绻朐诤蠖嗽O(shè)置跨域請求 需要設(shè)置頭信息
所以需要在后端中設(shè)置頭的來源
下面改下java代碼
在UsersController中
image.png

我們在用戶id這個api中加入了跨域請求設(shè)置
重新發(fā)布代碼
再次訪問http://localhost:8999/test.html
結(jié)果如下
image.png

和我們api中返回的值相同
image.png

這種跨域請求方式是通過HttpServletResponse加入請求頭的方式 不是很方便
下面我們看下第二種方式跨域請求(加入注解的方式@CrossOrigin)可以在官網(wǎng)中搜索
可以在類的某個方法中對其進(jìn)行跨域設(shè)置
image.png

下面我們代碼演示下
image.png

重新發(fā)布下代碼
再次訪問http://localhost:8999/test.html
image.png

發(fā)現(xiàn)正常的彈出了用戶名
下面我們把test.html中改成POST方式請求
代碼如下
image.png

再次訪問http://localhost:8999/test.html
image.png

是因?yàn)槲覀僓sersController中使用的是@GetMapping
下面改為@PostMapping
image.png

再次發(fā)布代碼
運(yùn)行http://localhost:8999/test.html
image.png

表示我們請求成功了
下面我們看下第三種設(shè)置跨域方法(全局設(shè)置)有兩種方式(一,xml配置二逢艘,WebConfig方式)
如果我們在每個Controller或者方法里面都要打上注解的話哨颂,還不是很方便
image.png

來到spring官網(wǎng) 全局搜索mvc:cors
可以看見下面一段配置
image.png

可以在我們的xml文件寫上配置
下面我們演示下xml方式
打開context-spring.xml
加入如下
<mvc:cors>

    <!--/** 表示users下面的所有都可以訪問-->
    <mvc:mapping path="/users/**"
                 allowed-origins="http://localhost:8999"
                 allowed-methods="GET, POST"
             />

    <mvc:mapping path="/resources/**"
                 allowed-origins="http://domain1.com" />

</mvc:cors>

在UsersController中注釋掉@CrossOrigin注解

image.png

再次發(fā)布代碼
運(yùn)行http://localhost:8999/test.html
結(jié)果
image.png

可以看見依然能夠正常顯示
以上就是三種設(shè)置后端跨域請求的方式 更多內(nèi)容查看我們的官網(wǎng)

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市剔氏,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌竹祷,老刑警劉巖谈跛,帶你破解...
    沈念sama閱讀 219,490評論 6 508
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異塑陵,居然都是意外死亡感憾,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,581評論 3 395
  • 文/潘曉璐 我一進(jìn)店門令花,熙熙樓的掌柜王于貴愁眉苦臉地迎上來阻桅,“玉大人凉倚,你說我怎么就攤上這事∩┏粒” “怎么了稽寒?”我有些...
    開封第一講書人閱讀 165,830評論 0 356
  • 文/不壞的土叔 我叫張陵,是天一觀的道長趟章。 經(jīng)常有香客問我杏糙,道長,這世上最難降的妖魔是什么蚓土? 我笑而不...
    開封第一講書人閱讀 58,957評論 1 295
  • 正文 為了忘掉前任宏侍,我火速辦了婚禮,結(jié)果婚禮上蜀漆,老公的妹妹穿的比我還像新娘谅河。我一直安慰自己,他們只是感情好嗜愈,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,974評論 6 393
  • 文/花漫 我一把揭開白布旧蛾。 她就那樣靜靜地躺著莽龟,像睡著了一般蠕嫁。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上毯盈,一...
    開封第一講書人閱讀 51,754評論 1 307
  • 那天剃毒,我揣著相機(jī)與錄音,去河邊找鬼搂赋。 笑死赘阀,一個胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的脑奠。 我是一名探鬼主播基公,決...
    沈念sama閱讀 40,464評論 3 420
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼宋欺!你這毒婦竟也來了轰豆?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 39,357評論 0 276
  • 序言:老撾萬榮一對情侶失蹤齿诞,失蹤者是張志新(化名)和其女友劉穎酸休,沒想到半個月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體祷杈,經(jīng)...
    沈念sama閱讀 45,847評論 1 317
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡斑司,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,995評論 3 338
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了但汞。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片宿刮。...
    茶點(diǎn)故事閱讀 40,137評論 1 351
  • 序言:一個原本活蹦亂跳的男人離奇死亡互站,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出僵缺,到底是詐尸還是另有隱情云茸,我是刑警寧澤,帶...
    沈念sama閱讀 35,819評論 5 346
  • 正文 年R本政府宣布谤饭,位于F島的核電站标捺,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏揉抵。R本人自食惡果不足惜亡容,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,482評論 3 331
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望冤今。 院中可真熱鬧闺兢,春花似錦、人聲如沸戏罢。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,023評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽龟糕。三九已至桐磁,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間讲岁,已是汗流浹背我擂。 一陣腳步聲響...
    開封第一講書人閱讀 33,149評論 1 272
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留缓艳,地道東北人校摩。 一個月前我還...
    沈念sama閱讀 48,409評論 3 373
  • 正文 我出身青樓,卻偏偏與公主長得像阶淘,于是被迫代替她去往敵國和親衙吩。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,086評論 2 355

推薦閱讀更多精彩內(nèi)容