1. <strong id="7actg"></strong>
    2. <table id="7actg"></table>

    3. <address id="7actg"></address>
      <address id="7actg"></address>
      1. <object id="7actg"><tt id="7actg"></tt></object>

        微信小程序開(kāi)發(fā)【前端+后端(Java)】

        共 5375字,需瀏覽 11分鐘

         ·

        2021-01-09 22:15

        來(lái)源:https://blog.csdn.net/zwb19940216



        一、前言

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

        二、主要內(nèi)容


        1. springboot后端架構(gòu)構(gòu)建

        2. 小程序項(xiàng)目構(gòu)建

        3. 小程序api調(diào)用

        4. 后臺(tái)resetful接口編寫(xiě)

        5. 小程序調(diào)用后臺(tái)接口

        6. 免費(fèi)的https申請(qǐng)

        7. linux下部署上線(xiàn)


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

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



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


        組件:??

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

        api:?

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


        四、后端詳解

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

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

        pom.xml依賴(lài)

              <parent>    <groupId>org.springframework.bootgroupId>    <artifactId>spring-boot-starter-parentartifactId>    <version>1.5.9.RELEASEversion>  parent>  <dependencies>            <dependency>      <groupId>org.springframework.bootgroupId>      <artifactId>spring-boot-starter-freemarkerartifactId>    dependency>
        <dependency> <groupId>org.springframework.bootgroupId> <artifactId>spring-boot-starter-webartifactId> dependency>
        <dependency> <groupId>org.springframework.bootgroupId> <artifactId>spring-boot-starter-webartifactId> <exclusions> <exclusion> <groupId>org.springframework.bootgroupId> <artifactId>spring-boot-starter-tomcatartifactId> exclusion> exclusions> dependency>
        <dependency> <groupId>org.apache.tomcat.embedgroupId> <artifactId>tomcat-embed-jasperartifactId> 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證書(shū)#ssl證書(shū)文件名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即可。

        在寫(xiě)一個(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 ("后來(lái)".equals(word)) {      message="正在熱映的后來(lái)的我們是劉若英的處女作。";    }else if("微信小程序".equals(word)){      message= "想獲取更多微信小程序相關(guān)知識(shí),請(qǐng)更多的閱讀微信官方文檔,還有其他更多微信開(kāi)發(fā)相關(guān)的內(nèi)容,學(xué)無(wú)止境。";    }else if("西安工業(yè)大學(xué)".equals(word)){      message="西安工業(yè)大學(xué)(Xi'an Technological University)簡(jiǎn)稱(chēng)”西安工大“,位于世界歷史名城古都西安,是中國(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è)試基本完成。

        說(shuō)明:@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框架開(kāi)發(fā)小程序后端的主要原因之一。可以方面我們進(jìn)行小程序的后端開(kāi)發(fā)。

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

        在完成了小程序的后端開(kāi)發(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/)。


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

        wxml文件:

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

        js文件:變量的定義見(jiàn)上一個(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)目在微信開(kāi)發(fā)工具上進(jìn)行測(cè)試。

        演示效果:



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


        六、ps申請(qǐng)


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


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


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

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

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

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


        八、源碼


        百度云鏈接:?

        https://pan.baidu.com/s/1PfByFfEgqkVALcc3PRhn9w?

        提取碼: c7yf


        PS:如果覺(jué)得我的分享不錯(cuò),歡迎大家隨手點(diǎn)贊、在看。
        END
        瀏覽 80
        點(diǎn)贊
        評(píng)論
        收藏
        分享

        手機(jī)掃一掃分享

        分享
        舉報(bào)
        評(píng)論
        圖片
        表情
        推薦
        點(diǎn)贊
        評(píng)論
        收藏
        分享

        手機(jī)掃一掃分享

        分享
        舉報(bào)
        1. <strong id="7actg"></strong>
        2. <table id="7actg"></table>

        3. <address id="7actg"></address>
          <address id="7actg"></address>
          1. <object id="7actg"><tt id="7actg"></tt></object>
            性爱资源站 | 91精品国产91久久久久久软件优势 | 国产无码免费在线观看 | 亚洲欧美日韩色图 | 在线亚洲日本 | 欧美精品免费播放 | P站免费版 - 永久免费的福利视频平台 | 亚洲va欧美va国产va影院 | 最新三级片在线播放 | 黄片播放 |