<kbd id="afajh"><form id="afajh"></form></kbd>
<strong id="afajh"><dl id="afajh"></dl></strong>
    <del id="afajh"><form id="afajh"></form></del>
        1. <th id="afajh"><progress id="afajh"></progress></th>
          <b id="afajh"><abbr id="afajh"></abbr></b>
          <th id="afajh"><progress id="afajh"></progress></th>

          微信小程序練手實(shí)戰(zhàn):前端+后端(Java)

          共 10593字,需瀏覽 22分鐘

           ·

          2021-03-10 14:17

          點(diǎn)擊上方“藍(lán)色字體”,選擇“設(shè)為星標(biāo)”

          做積極的人,而不是積極廢人!


          作者:BingeZha

          csdn.net/zwb19940216/article/details/81023191

          1.  前言

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

          2.  主要內(nèi)容

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

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

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

          這里寫圖片描述

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

          組件

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

          api:

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

          4.  后端詳解

          我在后端編寫主要是用java,當(dāng)然對(duì)其他開發(fā)語(yǔ)言熟悉的也可以使用其他語(yǔ)言開發(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=.jsp
          spring.mvc.view.prefix=/WEB-INF/jsp/
          #this is set port
          #server.port=80
          server.port=443
          #添加ssl證書
          #ssl證書文件名
          server.ssl.key-store=classpath:xxxxxxx.pfx
          server.ssl.key-store-password=xxxxxxxx
          server.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= "")
          @EnableAutoConfiguration
          public class App{

           //啟動(dòng)springboot
           public static void main(String[] args) {
            SpringApplication.run(App.classargs);
           }
          }

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

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

          @RestController
          @SpringBootApplication
          public 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é)無(wú)止境。";
            }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ā)。

          5.  小程序發(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:''

            },
            houduanButton1function ({
              var that = this;
              wx.request({
                url'http://localhost:443/getUser',
                method'GET',
                header: {
                  'content-type''application/json' // 默認(rèn)值
                },
                successfunction (res{
                  console.log(res.data)//打印到控制臺(tái)
                  var list = res.data.list;
                  if (list == null) {
                    var toastText = '數(shù)據(jù)獲取失敗';
                    wx.showToast({
                      title: toastText,
                      icon'',
                      duration2000
                    });
                  } else {
                    that.setData({
                      list: list
                    })
                  }
                }
              })
            }

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

          接下來以搜索類型的請(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_inputfunction (e{
              this.setData({
                word: e.detail.value
              })
            },
            // houduanButton2的網(wǎng)絡(luò)請(qǐng)求
            houduanButton2function ({
              var that = this;
              wx.request({
                url'http://localhost:443/getWord',
                data:{
                  word: that.data.word
                },
                method'GET',
                header: {
                  'content-type''application/json' // 默認(rèn)值
                },
                successfunction (res{
                  console.log(res.data)//打印到控制臺(tái)
                  var message = res.data.message;
                  if (message == null) {
                    var toastText = '數(shù)據(jù)獲取失敗';
                    wx.showToast({
                      title: toastText,
                      icon'',
                      duration2000
                    });
                  } else {
                    that.setData({
                      message: message
                    })
                  }
                }
              })
            }

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

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

          演示效果:

          這里寫圖片描述

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

          6.  https申請(qǐng)

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

          7.  購(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

          源碼:

          鏈接: https://pan.baidu.com/s/1PfByFfEgqkVALcc3PRhn9w 提取碼: c7yf

          - end -


          用心分享面試知識(shí),做有溫度的攻城獅

          每天記得對(duì)自己說:你是最棒的!


          往期推薦:

          每一個(gè)“好看”,都是對(duì)我們最大的幫助

          瀏覽 57
          點(diǎn)贊
          評(píng)論
          收藏
          分享

          手機(jī)掃一掃分享

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

          手機(jī)掃一掃分享

          分享
          舉報(bào)
          <kbd id="afajh"><form id="afajh"></form></kbd>
          <strong id="afajh"><dl id="afajh"></dl></strong>
            <del id="afajh"><form id="afajh"></form></del>
                1. <th id="afajh"><progress id="afajh"></progress></th>
                  <b id="afajh"><abbr id="afajh"></abbr></b>
                  <th id="afajh"><progress id="afajh"></progress></th>
                  欧美三级黄色全部 | 天天天日天天天天天天天日歌词 | 色屁屁在线 | 日韩精品电影无码 | 日屄免费 |