无码人妻丰满熟妇奶水区码,麻豆一区区三,亚洲日韩欧美精品综合,亚洲无码地址

微信小程序開發(fā)「前端+后端(Java)」附完整源碼(微信小程序前后端開發(fā)工具)

一、前言

現(xiàn)在微信小程序越來越火了,相信不少人都通過各種途徑學(xué)習(xí)過微信小程序或者嘗試開發(fā),作者就是曾經(jīng)由于興趣了解開發(fā)過微信小程序,所以現(xiàn)在用這篇博客記錄我之前開發(fā)的一些經(jīng)驗(yàn)和一些心得吧。

微信小程序開發(fā)「前端+后端(Java)」附完整源碼(微信小程序前后端開發(fā)工具)

二、主要內(nèi)容

  1. springboot后端架構(gòu)構(gòu)建
  2. 小程序項(xiàng)目構(gòu)建
  3. 小程序api調(diào)用
  4. 后臺(tái)resetful接口編寫
  5. 小程序調(diào)用后臺(tái)接口
  6. 免費(fèi)的https申請(qǐng)
  7. linux下部署上線

微信小程序開發(fā)「前端+后端(Java)」附完整源碼(微信小程序前后端開發(fā)工具)

三、微信小程序項(xiàng)目構(gòu)建

這些基礎(chǔ)的東西我就不過多介紹,大家在剛開始開發(fā)的時(shí)候一般都沒有自己的服務(wù)器及域名,所以大家在本地編寫的時(shí)候,在“詳細(xì)”下的“項(xiàng)目設(shè)置”里面將“不校驗(yàn)域名安全性”勾選。

微信小程序開發(fā)「前端+后端(Java)」附完整源碼(微信小程序前后端開發(fā)工具)

至于微信小程序的組件,即前端頁(yè)面的開發(fā)希望大家耐住寂寞認(rèn)真在微信開發(fā)平臺(tái)上。

組件:

https://developers.weixin.qq.com/miniprogram/dev/component/

api:

https://developers.weixin.qq.com/miniprogram/dev/api/

四、后端詳解

我在后端編寫主要是用Java,當(dāng)然對(duì)其他開發(fā)語言熟悉的也可以使用其他語言開發(fā)后端?,F(xiàn)在我就java編寫后端api的講解。主要框架springboot,開發(fā)工具myeclipse,服務(wù)器阿里云服務(wù)器。

創(chuàng)建一個(gè)maven項(xiàng)目,導(dǎo)入相關(guān)依賴:

pom.xml依賴

<!-- 統(tǒng)一版本控制 --> <parent> <groupId>org.Springframework.boot</groupId> <artifactId>spring-boot-starter-parent</artifactId> <version>1.5.9.RELEASE</version> </parent> <dependencies> <!-- freemarker渲染頁(yè)面 --> <!-- https://mvnrepository.com/artifact/org.springframework.boot/spring-boot-starter-freemarker --> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-freemarker</artifactId> </dependency> <!-- spring boot 核心 --> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-web</artifactId> </dependency> <!-- springboot整合jsp --> <!-- tomcat 的支持. --> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-web</artifactId> <exclusions> <exclusion> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-tomcat</artifactId> </exclusion> </exclusions> </dependency> <dependency> <groupId>org.apache.tomcat.embed</groupId> <artifactId>tomcat-embed-jasper</artifactId> </dependency> </dependencies>

在配置文件src/main/resources/下創(chuàng)建application.properties文件可以修改一些配置參數(shù)等。

#jsp支持spring.mvc.view.suffix=.jspspring.mvc.view.prefix=/WEB-INF/jsp/#this is set port#server.port=80server.port=443#添加ssl證書#ssl證書文件名server.ssl.key-store=classpath:xxxxxxx.pfxserver.ssl.key-store-password=xxxxxxxxserver.ssl.keyStoreType=xxxxxxxx

在實(shí)際項(xiàng)目中可能涉及數(shù)據(jù)庫(kù),還要整合mybatis,在文章中,我僅僅做測(cè)試就不做使用數(shù)據(jù)庫(kù)的測(cè)試。

首先創(chuàng)建springboot的入口程序:app.class下面貼上代碼:

@ComponentScan(basePackages= "com.bin")//添加掃包@ComponentScan(basePackages= "")@EnableAutoConfigurationpublic class App{ //啟動(dòng)springboot public static void main(String[] args) { SpringApplication.run(App.class, args); }}

啟動(dòng)項(xiàng)目時(shí)直接右擊run即可。

在寫一個(gè)測(cè)試的controller進(jìn)行微信小程序與java后端實(shí)現(xiàn)通信,controller代碼如下:

@RestController@SpringBootApplicationpublic class ControllerText { @RequestMapping("getUser") public Map<String, Object> getUser(){ System.out.println("微信小程序正在調(diào)用。。。"); Map<String, Object> map = new HashMap<String, Object>(); List<String> list = new ArrayList<String>(); list.add("zhangsan"); list.add("lisi"); list.add("wanger"); list.add("mazi"); map.put("list",list); System.out.println("微信小程序調(diào)用完成。。。"); return map; } @RequestMapping("getWord") public Map<String, Object> getText(String word){ Map<String, Object> map = new HashMap<String, Object>(); String message = "我能力有限,不要為難我"; if ("后來".equals(word)) { message="正在熱映的后來的我們是劉若英的處女作。"; }else if("微信小程序".equals(word)){ message= "想獲取更多微信小程序相關(guān)知識(shí),請(qǐng)更多的閱讀微信官方文檔,還有其他更多微信開發(fā)相關(guān)的內(nèi)容,學(xué)無止境。"; }else if("西安工業(yè)大學(xué)".equals(word)){ message="西安工業(yè)大學(xué)(Xi'an Technological University)簡(jiǎn)稱”西安工大“,位于世界歷史名城古都西安,是中國(guó)西北地區(qū)唯一一所以兵工為特色,以工為主,理、文、經(jīng)、管、法協(xié)調(diào)發(fā)展的教學(xué)研究型大學(xué)。原中華人民共和國(guó)兵器工業(yè)部直屬的七所本科院校之一(“兵工七子”),陜西省重點(diǎn)建設(shè)的高水平教學(xué)研究型大學(xué)、陜西省人民政府與中國(guó)兵器工業(yè)集團(tuán)、國(guó)防科技工業(yè)局共建高校、教育部“卓越工程師教育培養(yǎng)計(jì)劃”試點(diǎn)高校、陜西省大學(xué)生創(chuàng)新能力培養(yǎng)綜合改革試點(diǎn)學(xué)校。國(guó)家二級(jí)保密資格單位,是一所以"軍民結(jié)合,寓軍于民"的國(guó)防科研高校。"; } map.put("message", message); return map; } @RequestMapping("") public String getText(){ return "hello world"; }}

至此簡(jiǎn)易的后端框架及測(cè)試基本完成。

說明:@RestController與@Controller注解的區(qū)別@RestController相當(dāng)于兩個(gè)注解,它能實(shí)現(xiàn)將后端得到的數(shù)據(jù)在前端頁(yè)面(網(wǎng)頁(yè))中以json串的形式傳遞。而微信小程序與后臺(tái)之間的數(shù)據(jù)傳遞就是以json報(bào)文的形式傳遞。所以這就是選擇springboot框架開發(fā)小程序后端的主要原因之一。可以方便我們進(jìn)行小程序的后端開發(fā)。

五、小程序發(fā)起網(wǎng)絡(luò)請(qǐng)求

在完成了小程序的后端開發(fā),下面進(jìn)行小程序端發(fā)起網(wǎng)絡(luò)請(qǐng)求。

下面以一個(gè)簡(jiǎn)單的按鈕請(qǐng)求數(shù)據(jù)為例:

wxml文件

<button bindtap='houduanButton1'>點(diǎn)擊發(fā)起請(qǐng)求</button><view wx:for="{{list}}"> 姓名:{{item}} </view>

js文件

/** * 頁(yè)面的初始數(shù)據(jù) */ data: { list: '', word: '', message:'' }, houduanButton1: function () { var that = this; wx.request({ url: 'http://localhost:443/getUser', method: 'GET', header: { 'content-type': 'application/json' // 默認(rèn)值 }, success: function (res) { console.log(res.data)//打印到控制臺(tái) var list = res.data.list; if (list == null) { var toastText = '數(shù)據(jù)獲取失敗'; wx.showToast({ title: toastText, icon: '', duration: 2000 }); } else { that.setData({ list: list }) } } }) }

主要調(diào)用的api就是wx.request,想知道將詳細(xì)的介紹大家可以去微信公眾平臺(tái)(https://developers.weixin.qq.com/miniprogram/dev/api/)。

接下來以搜索類型的請(qǐng)求為例:

wxml文件:

<input type="text" class="houduanTab_input" placeholder="請(qǐng)輸入你要查詢的內(nèi)容" bindinput='houduanTab_input'></input> <button bindtap='houduanButton2'>查詢</button> <view wx:if="{{message!=''}}"> {{message}} </view>

js文件:變量的定義見上一個(gè)js文件

//獲取輸入框的內(nèi)容 houduanTab_input: function (e) { this.setData({ word: e.detail.value }) }, // houduanButton2的網(wǎng)絡(luò)請(qǐng)求 houduanButton2: function () { var that = this; wx.request({ url: 'http://localhost:443/getWord', data:{ word: that.data.word }, method: 'GET', header: { 'content-type': 'application/json' // 默認(rèn)值 }, success: function (res) { console.log(res.data)//打印到控制臺(tái) var message = res.data.message; if (message == null) { var toastText = '數(shù)據(jù)獲取失敗'; wx.showToast({ title: toastText, icon: '', duration: 2000 }); } else { that.setData({ message: message }) } } }) }

至此已經(jīng)完成了簡(jiǎn)易的微信小程序端與java后端進(jìn)行通信。

現(xiàn)在可以在啟動(dòng)后端項(xiàng)目在微信開發(fā)工具上進(jìn)行測(cè)試。

演示效果:

微信小程序開發(fā)「前端+后端(Java)」附完整源碼(微信小程序前后端開發(fā)工具)微信小程序開發(fā)「前端+后端(Java)」附完整源碼(微信小程序前后端開發(fā)工具)

所以至此已經(jīng)完成了小程序的前后端通信。

六、ps申請(qǐng)

其實(shí)也不算什么申請(qǐng),在購(gòu)買域名之后可以申請(qǐng)免費(fèi)的ssl證書,在前面的配置文件application.properties中有證書的配置,將證書的pfx文件直接添加到后端項(xiàng)目下即可。

微信小程序開發(fā)「前端+后端(Java)」附完整源碼(微信小程序前后端開發(fā)工具)

七、購(gòu)買服務(wù)器部署后端api代碼

對(duì)于springboot項(xiàng)目,本人建議打jar,直接在服務(wù)器上部署即可,在服務(wù)器上只需要安裝對(duì)應(yīng)版本的jdk即可。項(xiàng)目部署命令:

我購(gòu)買的是阿里云的輕量級(jí)應(yīng)用服務(wù)器部署的。比較劃算吧。

運(yùn)行命令: nohup java -jar helloworld.jar &

nohup的意思不掛服務(wù),常駐的意思,除非云服務(wù)器重啟,那就沒法了;最后一個(gè)&表示執(zhí)行命令后要生成日志文件nohup.out,當(dāng)然還可以使用java -jar helloworld.jar。

八、面試題資料領(lǐng)取方式

2021年MySQL數(shù)據(jù)庫(kù)面試題總結(jié)(50道題含答案解析)
77道JVM系列面試題總結(jié)(2萬字解析)
Spring Cloud面試題萬字解析(2021面試必備)
面試官:你對(duì)Redis緩存了解嗎?面對(duì)這11道面試題你是否有很多問號(hào)?
2021年Java多線程與并發(fā)系列22道高頻面試題解析
2021年Java基礎(chǔ)高頻面試題匯總(1.4W字詳細(xì)解析)
全網(wǎng)最全Spring系列面試題129道(附答案解析)
85道Java微服務(wù)面試題整理(助力2021面試)
2021年面試官最喜歡問的28道ZooKeeper面試題
2021面試還搞不懂MyBatis?看看這27道面試題?。ê鸢负退季S導(dǎo)圖)
2021年常見的Linux面試題及答案解析,哪些你還不會(huì)?
2021年常見Elasticsearch面試題答案解析
18道kafka高頻面試題哪些你還不會(huì)?(含答案和思維導(dǎo)圖)
2021年12道RabbitMQ高頻面試題你都會(huì)了嗎?(含答案解析)
2021年Dubbo你掌握得如何?快看看這30道高頻面試題!

微信小程序開發(fā)「前端+后端(Java)」附完整源碼(微信小程序前后端開發(fā)工具)

面試題獲取方式:關(guān)注小編 轉(zhuǎn)發(fā)文章 私信【13】免費(fèi)獲取
重要的事情說三遍,轉(zhuǎn)發(fā) 轉(zhuǎn)發(fā) 轉(zhuǎn)發(fā),一定要記得點(diǎn)贊轉(zhuǎn)發(fā)哦!!!

版權(quán)聲明:本文內(nèi)容由互聯(lián)網(wǎng)用戶自發(fā)貢獻(xiàn),該文觀點(diǎn)僅代表作者本人。本站僅提供信息存儲(chǔ)空間服務(wù),不擁有所有權(quán),不承擔(dān)相關(guān)法律責(zé)任。如發(fā)現(xiàn)本站有涉嫌抄襲侵權(quán)/違法違規(guī)的內(nèi)容, 請(qǐng)發(fā)送郵件至 舉報(bào),一經(jīng)查實(shí),本站將立刻刪除。

(0)
上一篇 2024年5月10日 上午11:24
下一篇 2024年5月10日 上午11:36

相關(guān)推薦

  • 臨床科研課題設(shè)計(jì)模板(臨床科研課題設(shè)計(jì)方案)

    四月芳菲,善學(xué)篤思?!笆澜缱x書日”到來之際,威科“醫(yī)學(xué)科研設(shè)計(jì)、寫作與投稿”全國(guó)巡講活動(dòng)周周上線,助力科研工匠精神,敬請(qǐng)持續(xù)關(guān)注! 威科“醫(yī)學(xué)科研設(shè)計(jì)、寫作與投稿”全國(guó)巡講活動(dòng)由威…

    2022年5月15日
    612
  • 新東方科研項(xiàng)目課程有哪些

    新東方科研項(xiàng)目課程有哪些 近年來,隨著教育行業(yè)的不斷發(fā)展,新東方科研項(xiàng)目課程也成為了越來越多學(xué)生選擇的專業(yè)課程之一。作為一所著名的在線教育機(jī)構(gòu),新東方科研項(xiàng)目課程不僅提供了豐富的學(xué)…

    科研百科 2025年5月13日
    4
  • cad探索者插件

    cad探索者插件: 設(shè)計(jì)軟件中不可或缺的工具 CAD探索者插件是CAD軟件中一款非常實(shí)用的工具,可以幫助用戶更輕松、高效地探索和分析建筑和工業(yè)設(shè)計(jì)師的圖紙。這款插件通過整合了各種強(qiáng)…

    科研百科 2024年10月14日
    25
  • 夢(mèng)見去了南極做科研項(xiàng)目

    夢(mèng)見去了南極做科研項(xiàng)目 我是一名研究人員,最近我一直在思考有關(guān)南極的問題。我還記得小時(shí)候看過的一個(gè)電影,里面南極的場(chǎng)景深深地印在我的腦海中。我想象著那里是寒冷,孤獨(dú)和神秘的世界,一…

    科研百科 2025年2月1日
    2
  • 項(xiàng)目施工進(jìn)度管理辦法

    項(xiàng)目施工進(jìn)度管理辦法 隨著工程的不斷推進(jìn),項(xiàng)目施工進(jìn)度管理變得越來越重要。為了確保項(xiàng)目的順利完成,我們制定了本項(xiàng)目施工進(jìn)度管理辦法,旨在規(guī)范施工進(jìn)度管理,提高項(xiàng)目管理水平和效率。 …

    科研百科 2024年5月25日
    50
  • 堅(jiān)持“五化”抓好基層黨建(五抓五化助推基層黨建)

    必須堅(jiān)持常態(tài)化。抓基層黨建并不是一朝一夕的事情,要把抓基層打基礎(chǔ)作為長(zhǎng)遠(yuǎn)之計(jì)和固本之策,一任接著一任干,一張藍(lán)圖繪到底,要常磨常新、堅(jiān)持不懈、久久為功,決不能打“突擊戰(zhàn)”、搞“一陣…

    科研百科 2023年7月25日
    230
  • 天然氣集氣站科研項(xiàng)目

    天然氣集氣站科研項(xiàng)目 天然氣集氣站是天然氣生產(chǎn)的重要環(huán)節(jié),對(duì)于保障國(guó)家能源安全具有重要作用。然而,隨著天然氣資源的不斷減少,如何高效、節(jié)能地收集和儲(chǔ)存天然氣成為了研究的熱點(diǎn)。 在這…

    科研百科 2025年5月8日
    2
  • 關(guān)于進(jìn)一步加強(qiáng)合同管理的通知

    關(guān)于進(jìn)一步加強(qiáng)合同管理的通知 各相關(guān)單位: 隨著市場(chǎng)經(jīng)濟(jì)的發(fā)展和競(jìng)爭(zhēng)的加劇,合同管理已成為保證合同有效執(zhí)行和避免合同風(fēng)險(xiǎn)的重要措施。為了確保合同管理的規(guī)范化和科學(xué)化,現(xiàn)將進(jìn)一步加強(qiáng)…

    科研百科 2024年9月18日
    26
  • 項(xiàng)目管理系統(tǒng)都有哪些

    項(xiàng)目管理系統(tǒng)是一種用于組織和管理項(xiàng)目的工具,能夠幫助項(xiàng)目經(jīng)理和團(tuán)隊(duì)更好地規(guī)劃和執(zhí)行項(xiàng)目,提高項(xiàng)目的效率和質(zhì)量。以下是一些常見的項(xiàng)目管理系統(tǒng): 1. Microsoft Projec…

    科研百科 2024年7月15日
    19
  • 黨建品牌創(chuàng)建步驟及措施

    黨建品牌創(chuàng)建步驟及措施 近年來,隨著社會(huì)的發(fā)展和進(jìn)步,中國(guó)共產(chǎn)黨(中共)的黨建工作也在不斷地推進(jìn)和加強(qiáng)。為了進(jìn)一步提高黨建工作的水平和效果,黨建品牌已經(jīng)成為了一種常見的推廣方式。在…

    科研百科 2024年10月7日
    25