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

? ? ?

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

1. 前言

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

2. 主要內容

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

3. 微信小程序項目構建

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

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

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

組件

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

api:

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

4. 后端詳解

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

創建一個maven項目,導入相關依賴:

pom.xml依賴

<!-- 統一版本控制 --><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/下創建application.properties文件可以修改一些配置參數等。

#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

在實際項目中可能涉及數據庫,還要整合mybatis,在文章中,我僅僅做測試就不做使用數據庫的測試。

首先創建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后端實現通信,controller代碼如下:

@RestController@SpringBootApplicationpublic class ControllerText {  @RequestMapping("getUser") public Map<String, Object> getUser(){  System.out.println("微信小程序正在調用。。。");  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("微信小程序調用完成。。。");  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= "想獲取更多微信小程序相關知識,請更多的閱讀微信官方文檔,還有其他更多微信開發相關的內容,學無止境。";  }else if("西安工業大學".equals(word)){   message="西安工業大學(Xi'an Technological University)簡稱”西安工大“,位于世界歷史名城古都西安,是中國西北地區唯一一所以兵工為特色,以工為主,理、文、經、管、法協調發展的教學研究型大學。原中華人民共和國兵器工業部直屬的七所本科院校之一(“兵工七子”),陜西省重點建設的高水平教學研究型大學、陜西省人民政府與中國兵器工業集團、國防科技工業局共建高校、教育部“卓越工程師教育培養計劃”試點高校、陜西省大學生創新能力培養綜合改革試點學校。國家二級保密資格單位,是一所以"軍民結合,寓軍于民"的國防科研高校。";  }  map.put("message", message);  return map; }  @RequestMapping("") public String getText(){  return "hello world"; }}

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

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

5. 小程序發起網絡請求

在完成了小程序的后端開發,下面進行小程序端發起網絡請求。

下面以一個簡單的按鈕請求數據為例:

wxml文件

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

js文件

 /**   * 頁面的初始數據   */  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 = '數據獲取失敗';          wx.showToast({            title: toastText,            icon: '',            duration: 2000          });        } else {          that.setData({            list: list          })        }      }    })  }

主要調用的api就是wx.request,想知道將詳細地介紹大家可以去微信公眾平臺。

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

wxml文件:

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

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

//獲取輸入框的內容  houduanTab_input: function (e) {    this.setData({      word: e.detail.value    })  },  // houduanButton2的網絡請求  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 = '數據獲取失敗';          wx.showToast({            title: toastText,            icon: '',            duration: 2000          });        } else {          that.setData({            message: message          })        }      }    })  }

至此已經完成了簡易的微信小程序端與java后端進行通信。

現在可以在啟動后端項目在微信開發工具上進行測試。

演示效果:

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

所以至此已經完成了小程序的前后端通信。

6. https申請

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

7. 購買服務器部署后端api代碼

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

我購買的是阿里云的輕量級應用服務器部署的。比較劃算吧。

運行命令:

 nohup java -jar helloworld.jar &

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

當然還可以使用java -jar helloworld.jar

版權聲明:本文內容由互聯網用戶自發貢獻,該文觀點僅代表作者本人。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。如發現本站有涉嫌抄襲侵權/違法違規的內容, 請發送郵件至 舉報,一經查實,本站將立刻刪除。

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

相關推薦

  • 參與科研項目證明

    參與科研項目證明 我是一名年輕的研究者,最近參與了一項關于自然語言處理領域的科研項目。這個項目旨在研究如何更好地理解和分析自然語言文本,從而更好地應用人工智能技術。 在項目中,我參…

    科研百科 2024年10月7日
    18
  • 合同管理包括哪些

    合同管理包括哪些內容 合同管理是一個非常重要的過程,可以幫助企業確保合同的有效性和合規性,同時也可以減少合同爭議和風險。在合同管理中,包括了以下方面: 1. 合同文本管理:合同文本…

    科研百科 2024年9月20日
    20
  • 券商投行內控指引出爐 三道防線有效架起內控體系(證券公司投行內控指引全文)

    旨在完善券商投行業務內控建設的靴子落地。近日,證監會就《證券公司投資銀行類業務內部控制指引(征求意見稿)》(以下簡稱《指引》)向社會公開征求意見,《指引》明確了投行類業務主體責任。…

    科研百科 2024年5月10日
    82
  • 社科類碩士申請科研項目

    社科類碩士申請科研項目 隨著改革開放的不斷深入,中國在經濟、政治、文化等領域都取得了長足的進步。同時,社會科學領域也越來越受到人們的關注。作為一名社科類碩士,如果想在科研領域有所建…

    科研百科 2025年5月22日
    0
  • 美術研究生科研項目多嗎

    美術研究生科研項目多嗎? 作為一名美術研究生,科研項目是一項重要的任務。科研項目的開展不僅可以提升美術研究生的學術水平,還可以為學術界做出貢獻。在美術研究生科研項目方面,可以說非常…

    科研百科 2025年5月23日
    1
  • 岳陽經開區:“看板管理”管出基層黨建高質量

    岳陽日報全媒體訊 (張冰明 周岳華)“其他支部學習活動開展得這么迅速,我們回去以后也要抓緊組織,不能落在后面啊。”11月30日,在經開區通海路管理處機關一樓大廳,北港社區書記馮岳新…

    科研百科 2024年2月1日
    79
  • 研究項目前期相關研究成果

    研究項目前期相關研究成果 隨著現代技術的飛速發展,各種科學研究也在不斷地推進。其中,人工智能作為一個重要的領域,在科學研究中的應用也越來越廣泛。為了更加深入地了解人工智能在科學研究…

    科研百科 2024年11月15日
    3
  • 縱向科研經費和橫向科研經費(縱向科研經費管理辦法)

    縱向科研經費管理辦法縱向科研經費管理辦法是國內外國內中小學校的經驗匯報,也是研究學校成果的最佳平臺。首先是改革經費管理措施的開放。學生經費在日常的教學、學習、生活等方面均發揮著重要…

    科研百科 2024年7月30日
    29
  • 重點科研項目 翻譯

    重點科研項目翻譯 近年來,隨著全球化的不斷深入,翻譯已成為一個非常重要的領域。翻譯不僅涉及到語言和文化的傳遞,還涉及到商業、科技、文化和政治等多個領域。因此,許多重點科研項目都需要…

    科研百科 2025年2月21日
    3
  • 企業項目管理系統的需求(企業項目管理系統設計)

    企業項目管理系統設計企業項目管理系統設計與評估1.工程技術開發工程技術是在工程活動和管理部門工作中對專業的應用的一門技術。工程技術主要是對企業內各部門的工程技術進行調控和維修、研究…

    科研百科 2024年7月29日
    38