无码人妻精一区二区三区,eeuss影院www在线观看,无码精品久久久久久人妻中字,日韩av高清在线看片

推薦新聞
微信小程序開發(fā)(后端Java)
發(fā)布者:深藍(lán)互聯(lián)
發(fā)布時間:2019-12-30
點擊:次

微信使用的開發(fā)語言和文件很「特殊」。

小程序所使用的程序文件類型大致分為以下幾種:

①WXML(WeiXin Mark Language,微信標(biāo)記語言)

②WXSS(WeiXin Style Sheet,微信樣式表)

③JS(Java,小程序的主體)

在語言方面,小程序看似重新定義了一套標(biāo)準(zhǔn)。但實際上,它們與「前端三件套」——HTML、CSS 和 Java——差不太多。

下面,我們就來對比一下小程序開發(fā)語言和「前端三件套」有什么異同點:

HTML 與 WXML:兩者差異比較大,如果之前沒有接觸過 Android 開發(fā),可能會覺得有些頭疼。事實上,WXML 更像是 Android 開發(fā)中的界面 XML 描述文件,適合于程序界面的構(gòu)建;而 HTML 則傾向于文章的展示(這與 HTML 的歷史有關(guān)),以及互聯(lián)網(wǎng)頁面的構(gòu)建。

WXSS 與 CSS:兩者在語言上幾乎沒有差別,可以直接通用。

JS 文件:小程序的 JS 文件與前端開發(fā)使用的 JS 幾乎沒有區(qū)別,只是小程序的 JS 新增了微信的一些 API 接口,并去除了一些不必要的功能(如 DOM)。

在語言上,小程序完全向?qū)W習(xí)成本最低的前端開發(fā)看齊,但這不代表所有前端開發(fā)者都能無縫遷移。

如果你是從前端開發(fā)轉(zhuǎn)向小程序,就需要注意這兩個點:

HTML 與 WXML 兩種文件的構(gòu)建思想差異較大,如果之前只接觸過前端開發(fā),需要一點時間才能適應(yīng) WXML 的編寫方法。

雖然小程序使用的是前端語言,但不代表可以繼續(xù)沿用前端的開發(fā)思想進(jìn)行開發(fā)。小程序?qū)η岸碎_發(fā)的要求從「構(gòu)建界面」升級成「開發(fā)完整應(yīng)用」,前端開發(fā)需要在意識上進(jìn)行轉(zhuǎn)變。
 

1.主要內(nèi)容

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

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

  小程序api調(diào)用

  后臺resetful接口編寫

  小程序調(diào)用后臺接口

  免費的https申請

  Linux下部署上線

2.后端詳解(Java編寫后端api)

  主要框架springboot,開發(fā)工具myeclipse,服務(wù)器阿里云服務(wù)器。

  創(chuàng)建一個maven項目,導(dǎo)入相關(guān)依賴: 
  pom.xml依賴

  

復(fù)制代碼
<!-- 統(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>
復(fù)制代碼

  在配置文件src/main/resources/下創(chuàng)建application.properties文件,可以修改一些配置參數(shù)等

復(fù)制代碼
#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
復(fù)制代碼

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

  首先創(chuàng)建springboot的入庫程序:app.class下為代碼:

  

復(fù)制代碼
@ComponentScan(basePackages= "com.bin")//添加掃包@ComponentScan(basePackages= "")
@EnableAutoConfiguration
public class App{

    //啟動springboot
    public static void main(String[] args) {
        SpringApplication.run(App.class, args);
    }
}
復(fù)制代碼

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

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

  

復(fù)制代碼
@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è)部直屬的七所本科院校之一(“兵工七子”),陜西省重點建設(shè)的高水平教學(xué)研究型大學(xué)、陜西省人民政府與中國兵器工業(yè)集團(tuán)、國防科技工業(yè)局共建高校、教育部“卓越工程師教育培養(yǎng)計劃”試點高校、陜西省大學(xué)生創(chuàng)新能力培養(yǎng)綜合改革試點學(xué)校。國家二級保密資格單位,是一所以\"軍民結(jié)合,寓軍于民\"的國防科研高校。";
        }
        map.put("message", message);
        return map;
    }

    @RequestMapping("")
    public String getText(){
        return "hello world";
    }


}
復(fù)制代碼

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

  說明:@RestController與Controller注解的區(qū)別

      @RestController相當(dāng)于它能實現(xiàn)將后端得到的數(shù)據(jù)在前端頁面(網(wǎng)頁)中以json串的形式傳遞。

      微信小程序與后臺數(shù)據(jù)之間的數(shù)據(jù)傳遞就是以json報文的形式傳遞。這也是選擇springboot框架開發(fā)小程序后臺的主要原因之一,可以方便進(jìn)行小程序后套開發(fā)

    

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

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

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

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

    js文件:

復(fù)制代碼
/**
   * 頁面的初始數(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
          })
        }
      }
    })
  }
復(fù)制代碼

  主要調(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文件

復(fù)制代碼
  //獲取輸入框的內(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
          })
        }
      }
    })
  }
復(fù)制代碼

 

  至此已經(jīng)完成了簡易的微信小程序端與java后端進(jìn)行通信。 
       現(xiàn)在可以在啟動后端項目在微信開發(fā)工具上進(jìn)行測試。 
演示效果:

這里寫圖片描述 
這里寫圖片描述
所以至此已經(jīng)完成了小程序的前后端通信。

 

1.https申請
  其實也不算什么申請,在購買域名之后可以申請免費的ssl證書,在前面的配置文件application.properties中有證書的配置,將證書的pfx文件直接添加到后端項目下即可。
2.購買服務(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

 

摘錄自:https://blog.csdn.net/zwb19940216/article/details/81023191

    https://blog.csdn.net/qq_38125123/article/details/69568667 

 

關(guān)注深藍(lán)互聯(lián)公眾號
Copyright ? 2013-2025 深藍(lán)互聯(lián) 版權(quán)所有
友情鏈接: