欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

微信小程序+后端(java)實(shí)現(xiàn)開發(fā)

 更新時間:2020年04月08日 10:17:42   作者:BingeZha  
這篇文章主要介紹了微信小程序+后端(java)實(shí)現(xiàn)開發(fā),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧

前言

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

主要內(nèi)容

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

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

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


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

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

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

后端詳解

我在后端編寫主要是用java,當(dāng)然對其他開發(fā)語言熟悉的也可以使用其他語言開發(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=.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í)際項目中可能涉及數(shù)據(jù)庫,還要整合mybatis,在文章中,我僅僅做測試就不做使用數(shù)據(jù)庫的測試。
首先創(chuàng)建springboot的入口程序:app.class下面貼上代碼:

@ComponentScan(basePackages= "com.bin")//添加掃包@ComponentScan(basePackages= "")
@EnableAutoConfiguration
public class App{

	//啟動springboot
	public static void main(String[] args) {
		SpringApplication.run(App.class, args);
	}
}

啟動項目時直接右擊run即可。
在寫一個測試的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)知識,請更多的閱讀微信官方文檔,還有其他更多微信開發(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è)部直屬的七所本科院校之一(“兵工七子”),陜西省重點(diǎn)建設(shè)的高水平教學(xué)研究型大學(xué)、陜西省人民政府與中國兵器工業(yè)集團(tuán)、國防科技工業(yè)局共建高校、教育部“卓越工程師教育培養(yǎng)計劃”試點(diǎn)高校、陜西省大學(xué)生創(chuàng)新能力培養(yǎng)綜合改革試點(diǎn)學(xué)校。國家二級保密資格單位,是一所以\"軍民結(jié)合,寓軍于民\"的國防科研高校。";
		}
		map.put("message", message);
		return map;
	}
	
	@RequestMapping("")
	public String getText(){
		return "hello world";
	}
}

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

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

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

在完成了小程序的后端開發(fā),下面進(jìn)行小程序端發(fā)起網(wǎng)絡(luò)請求。
下面以一個簡單的按鈕請求數(shù)據(jù)為例:
wxml文件

<button bindtap='houduanButton1'>點(diǎn)擊發(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' // 默認(rèn)值
   },
   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,想知道將詳細(xì)的介紹大家可以去微信公眾平臺。
接下來以搜索類型的請求為例:
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' // 默認(rèn)值
   },
   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后端進(jìn)行通信。
現(xiàn)在可以在啟動后端項目在微信開發(fā)工具上進(jìn)行測試。
演示效果:



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

https申請

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

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

對于springboot項目,本人建議打jar,直接在服務(wù)器上部署即可,在服務(wù)器上只需要安裝對應(yīng)版本的jdk即可。項目部署命令:
我購買的是阿里云的輕量級應(yīng)用服務(wù)器部署的。比較劃算吧。

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

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

源碼:java-wechat_jb51.rar

到此這篇關(guān)于微信小程序+后端(java)實(shí)現(xiàn)開發(fā)的文章就介紹到這了,更多相關(guān)微信小程序java開發(fā)內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • Java中一些基礎(chǔ)概念的使用詳解

    Java中一些基礎(chǔ)概念的使用詳解

    本篇文章是對在Java中一些基礎(chǔ)概念的使用進(jìn)行了詳細(xì)的分析介紹,需要的朋友參考下
    2013-05-05
  • 詳解SpringBoot下文件上傳與下載的實(shí)現(xiàn)

    詳解SpringBoot下文件上傳與下載的實(shí)現(xiàn)

    這篇文章主要介紹了SpringBoot下文件上傳與下載的實(shí)現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-05-05
  • Spring @Import注解的使用

    Spring @Import注解的使用

    @Import注解算是SpringBoot自動配置原理中一個很重要的注解,本文介紹了該注解的源碼分析及使用方法,感興趣的朋友可以了解下
    2021-05-05
  • 實(shí)例詳解Java實(shí)現(xiàn)圖片與base64字符串之間的轉(zhuǎn)換

    實(shí)例詳解Java實(shí)現(xiàn)圖片與base64字符串之間的轉(zhuǎn)換

    這篇文章主要介紹了Java實(shí)現(xiàn)圖片與base64字符串之間的轉(zhuǎn)換實(shí)例代碼,非常不錯,具有參考借鑒價值,需要的朋友參考下
    2016-12-12
  • Java實(shí)現(xiàn)簡易版猜燈謎游戲的示例代碼

    Java實(shí)現(xiàn)簡易版猜燈謎游戲的示例代碼

    燈謎是中秋節(jié)傳統(tǒng)的活動之一,而現(xiàn)代化的方式則是將其制作成一個小游戲,讓用戶在游戲的過程中猜燈謎,互動體驗(yàn)更佳,所以本文小編就用Java制作一款猜燈謎小游戲吧
    2023-09-09
  • SpringBoot中的自定義starter詳解

    SpringBoot中的自定義starter詳解

    這篇文章主要介紹了SpringBoot中的自定義starter詳解,SpringBoot中的starter是一種非常重要的機(jī)制,能夠拋棄以前繁雜的配置,將其統(tǒng)一集成進(jìn)starter,需要的朋友可以參考下
    2024-01-01
  • Java數(shù)組的遍歷與求和知識點(diǎn)

    Java數(shù)組的遍歷與求和知識點(diǎn)

    本篇文章給大家總計了Java數(shù)組的遍歷與求和的知識點(diǎn)以及需要注意的地方,需要的朋友參考學(xué)習(xí)下。
    2018-02-02
  • Java中Buffer緩沖區(qū)的ByteBuffer類詳解

    Java中Buffer緩沖區(qū)的ByteBuffer類詳解

    這篇文章主要介紹了Java中Buffer緩沖區(qū)的ByteBuffer類詳解,ByteBuffer類是Java NIO庫中的一個重要類,用于處理字節(jié)數(shù)據(jù),它提供了一種靈活的方式來讀取、寫入和操作字節(jié)數(shù)據(jù),ByteBuffer類是一個抽象類,可以通過靜態(tài)方法創(chuàng)建不同類型的ByteBuffer對象,需要的朋友可以參考下
    2023-10-10
  • 淺析Spring4新特性概述

    淺析Spring4新特性概述

    Spring 4.1并沒有特別吸引眼球的地方,主要還是增強(qiáng)和一些依賴的版本升級。本文重點(diǎn)給大家介紹Spring4新特性概述,感興趣的朋友一起看看吧
    2017-09-09
  • Java Lambda 表達(dá)式詳解及示例代碼

    Java Lambda 表達(dá)式詳解及示例代碼

    本文主要介紹Java Lambda 表達(dá)式的知識,這里整理了相關(guān)資料,JavaLambda 是Java8 引入的新功能,有興趣的小伙伴可以參考下
    2016-09-09

最新評論