亚州天堂爱爱,做爱视频国产全过程在线观看,成人试看30分钟免费视频,女人无遮挡裸交性做爰视频网站

? ? ?

微信小程序練手實戰(zhàn):前端+后端(Java)(微信小程序前端和后端是怎么工作的)

1. 前言

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

2. 主要內(nèi)容

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

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

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

微信小程序練手實戰(zhàn):前端+后端(Java)(微信小程序前端和后端是怎么工作的)

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

組件

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

api:

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

4. 后端詳解

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

創(chuàng)建一個maven項目,導(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渲染頁面 --> <!-- 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ù)據(jù)庫,還要整合mybatis,在文章中,我僅僅做測試就不做使用數(shù)據(jù)庫的測試。

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

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

啟動項目時直接右擊run即可。

在寫一個測試的controller進行微信小程序與java后端實現(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)知識,請更多的閱讀微信官方文檔,還有其他更多微信開發(fā)相關(guān)的內(nèi)容,學(xué)無止境。";  }else if("西安工業(yè)大學(xué)".equals(word)){   message="西安工業(yè)大學(xué)(Xi'an Technological University)簡稱”西安工大“,位于世界歷史名城古都西安,是中國西北地區(qū)唯一一所以兵工為特色,以工為主,理、文、經(jīng)、管、法協(xié)調(diào)發(fā)展的教學(xué)研究型大學(xué)。原中華人民共和國兵器工業(yè)部直屬的七所本科院校之一(“兵工七子”),陜西省重點建設(shè)的高水平教學(xué)研究型大學(xué)、陜西省人民政府與中國兵器工業(yè)集團、國防科技工業(yè)局共建高校、教育部“卓越工程師教育培養(yǎng)計劃”試點高校、陜西省大學(xué)生創(chuàng)新能力培養(yǎng)綜合改革試點學(xué)校。國家二級保密資格單位,是一所以"軍民結(jié)合,寓軍于民"的國防科研高校。";  }  map.put("message", message);  return map; }  @RequestMapping("") public String getText(){  return "hello world"; }}

至此簡易的后端框架及測試基本完成。

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

5. 小程序發(fā)起網(wǎng)絡(luò)請求

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

下面以一個簡單的按鈕請求數(shù)據(jù)為例:

wxml文件

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

js文件

 /**   * 頁面的初始數(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' // 默認值      },      success: function (res) {        console.log(res.data)//打印到控制臺        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,想知道將詳細地介紹大家可以去微信公眾平臺。

接下來以搜索類型的請求為例:

wxml文件:

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

js文件:變量的定義見上一個js文件

//獲取輸入框的內(nèi)容  houduanTab_input: function (e) {    this.setData({      word: e.detail.value    })  },  // houduanButton2的網(wǎng)絡(luò)請求  houduanButton2: function () {    var that = this;    wx.request({      url: 'http://localhost:443/getWord',      data:{        word: that.data.word      },      method: 'GET',      header: {        'content-type': 'application/json' // 默認值      },      success: function (res) {        console.log(res.data)//打印到控制臺        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)完成了簡易的微信小程序端與java后端進行通信。

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

演示效果:

微信小程序練手實戰(zhàn):前端+后端(Java)(微信小程序前端和后端是怎么工作的)微信小程序練手實戰(zhàn):前端+后端(Java)(微信小程序前端和后端是怎么工作的)

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

6. https申請

其實也不算什么申請,在購買域名之后可以申請免費的ssl證書,在前面的配置文件application.properties中有證書的配置,將證書的pfx文件直接添加到后端項目下即可。

7. 購買服務(wù)器部署后端api代碼

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

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

運行命令:

 nohup java -jar helloworld.jar &

nohup的意思不掛服務(wù),常駐的意思,除非云服務(wù)器重啟,那就沒法了;最后一個&表示執(zhí)行命令后要生成日志文件nohup.out。

當(dāng)然還可以使用java -jar helloworld.jar

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

(0)
上一篇 2023年4月5日 上午9:54
下一篇 2023年4月5日 上午10:10

相關(guān)推薦

  • 什么是科研項目包干制

    科研項目包干制是指一種對科研項目經(jīng)費進行集中管理、統(tǒng)一支付、分散使用的管理方式。它適用于各種類型的科研項目,包括自然科學(xué)、工程技術(shù)、社會科學(xué)、醫(yī)學(xué)等。 科研項目包干制的目的是使科研…

    科研百科 2025年5月1日
    8
  • 與高校合作的科研項目

    與高校合作的科研項目 近年來,隨著科技的飛速發(fā)展,科研項目已經(jīng)成為高校教學(xué)和科研的重要載體。為了更好地推動科技進步和社會發(fā)展,許多高校都與國內(nèi)外的研究機構(gòu)和企業(yè)展開深入的合作,共同…

    科研百科 2025年3月30日
    2
  • 系統(tǒng)設(shè)計與管理項目名稱

    系統(tǒng)設(shè)計與管理 隨著計算機技術(shù)的不斷發(fā)展,越來越多的企業(yè)和個人開始關(guān)注系統(tǒng)設(shè)計與管理。系統(tǒng)設(shè)計和管理對于企業(yè)和個人來說至關(guān)重要,可以提高系統(tǒng)的可用性、可維護性和可擴展性,從而提升整…

    科研百科 2025年1月18日
    1
  • 醫(yī)療衛(wèi)生科研項目評審標(biāo)準(zhǔn)

    醫(yī)療衛(wèi)生科研項目評審標(biāo)準(zhǔn) 醫(yī)療衛(wèi)生科研項目評審標(biāo)準(zhǔn)是確保科研項目質(zhì)量的重要保障,其重要性不言而喻。一份優(yōu)秀的科研項目評審標(biāo)準(zhǔn)不僅能夠保證科研項目的質(zhì)量,還能夠提高科研項目的可信度和…

    科研百科 2025年5月3日
    1
  • 通過專業(yè)注冊服務(wù)快速有效地創(chuàng)辦售電公司的終極指南

    介紹 售電公司是指在電力市場中,為用電客戶提供電力交易、咨詢、代理等服務(wù)的企業(yè)。售電公司注冊流程包括以下幾個步驟: 注冊售電公司,具有獨立法人資格,經(jīng)營范圍包含售電行業(yè)。 注冊資金…

    科研百科 2023年4月2日
    117
  • 藍云項目管理系統(tǒng)開發(fā)

    藍云項目管理系統(tǒng)開發(fā):從需求分析到部署上線 隨著現(xiàn)代軟件開發(fā)的不斷推進,項目管理系統(tǒng)已經(jīng)成為軟件開發(fā)中不可或缺的一部分。一個好的項目管理系統(tǒng)可以提高開發(fā)效率,降低開發(fā)成本,同時也可…

    科研百科 2025年7月5日
    1
  • 科研項目人才資助

    科研項目人才資助:推動科技創(chuàng)新,促進社會進步 科研項目是科技創(chuàng)新的核心,是推動社會發(fā)展的重要力量。而科研項目人才資助則是支持科研項目人才發(fā)展的重要措施,它能夠為科研項目人才提供必要…

    科研百科 2025年2月28日
    1
  • 學(xué)生科研項目模板

    學(xué)生科研項目模板 學(xué)生科研項目模板是學(xué)生在完成課程要求后,為探索某一領(lǐng)域問題而開展的研究項目。這些項目通常由導(dǎo)師或教授指導(dǎo),并經(jīng)過一定的準(zhǔn)備和規(guī)劃,以期望獲得一定的成果。以下是一篇…

    科研百科 2025年2月9日
    2
  • 施工進度管理

    施工進度管理是建筑工程項目管理中非常重要的一環(huán),它是保證項目按時按質(zhì)完成的重要保障。合理的施工進度管理不僅能夠提高項目的效率,還能夠降低項目的成本,提高項目的質(zhì)量。本文將介紹施工進…

    科研百科 2025年1月10日
    1
  • 人事管理系統(tǒng)項目確立

    人事管理系統(tǒng)項目確立 隨著企業(yè)規(guī)模的擴大和業(yè)務(wù)的不斷多元化,人事管理也變得越來越復(fù)雜。為了更好地管理企業(yè)的人力資源,開發(fā)一套高效的人事管理系統(tǒng)變得至關(guān)重要。本文將介紹如何確立人事管…

    科研百科 2025年6月16日
    0