三国志14信息查询小程序(历史武将信息一览)制作更新过程05-后台接口的编写及调用
1,创建ASP.NET Web API项目



生成完毕,项目结构如下:

运行看一下:

2,后台接口编写
(1)在Models文件夹中新建一个sandata.cs文件(就是上篇中武将信息表的model文件)
using SqlSugar;
using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;namespace API.Models
{public class Sandata{/// <summary>/// Desc:/// Default:/// Nullable:False/// </summary> [SugarColumn(IsPrimaryKey=true)]public int Id {get;set;}/// <summary>/// Desc:/// Default:/// Nullable:True/// </summary> public string sex {get;set;}/// <summary>/// Desc:/// Default:/// Nullable:True/// </summary> public int tongshuai {get;set;}/// <summary>/// Desc:/// Default:/// Nullable:True/// </summary> public int wuli {get;set;}/// <summary>/// Desc:/// Default:/// Nullable:True/// </summary> public int zhili {get;set;}/// <summary>/// Desc:/// Default:/// Nullable:True/// </summary> public int zhengzhi {get;set;}/// <summary>/// Desc:/// Default:/// Nullable:True/// </summary> public int meili {get;set;}/// <summary>/// Desc:/// Default:/// Nullable:True/// </summary> public string zhuyi {get;set;}/// <summary>/// Desc:/// Default:/// Nullable:True/// </summary> public string zhengce {get;set;}/// <summary>/// Desc:/// Default:/// Nullable:True/// </summary> public string zhengcedengji {get;set;}/// <summary>/// Desc:/// Default:/// Nullable:True/// </summary> public string peiou {get;set;}/// <summary>/// Desc:/// Default:/// Nullable:True/// </summary> public string name {get;set;}/// <summary>/// Desc:/// Default:/// Nullable:True/// </summary> public string gexing1 {get;set;}/// <summary>/// Desc:/// Default:/// Nullable:True/// </summary> public string gexing2 {get;set;}/// <summary>/// Desc:/// Default:/// Nullable:True/// </summary> public string gexing3 {get;set;}/// <summary>/// Desc:/// Default:/// Nullable:True/// </summary> public string gexing4 {get;set;}/// <summary>/// Desc:/// Default:/// Nullable:True/// </summary> public string gexing5 {get;set;}/// <summary>/// Desc:/// Default:/// Nullable:True/// </summary> public string shengnian {get;set;}/// <summary>/// Desc:/// Default:/// Nullable:True/// </summary> public string dengchang {get;set;}/// <summary>/// Desc:/// Default:/// Nullable:True/// </summary> public string zunian {get;set;}/// <summary>/// Desc:/// Default:/// Nullable:True/// </summary> public string hjqy { get; set; }/// <summary>/// Desc:/// Default:/// Nullable:True/// </summary> public string fdlm { get; set; }/// <summary>/// Desc:/// Default:/// Nullable:True/// </summary> public string eyyx { get; set; }/// <summary>/// Desc:/// Default:/// Nullable:True/// </summary> public string qxgj { get; set; }/// <summary>/// Desc:/// Default:/// Nullable:True/// </summary> public string gdzz { get; set; }/// <summary>/// Desc:/// Default:/// Nullable:True/// </summary> public string sgml { get; set; }/// <summary>/// Desc:/// Default:/// Nullable:True/// </summary> public string cbzz { get; set; }/// <summary>/// Desc:/// Default:/// Nullable:True/// </summary> public string hzzdz { get; set; }/// <summary>/// Desc:/// Default:/// Nullable:True/// </summary> public string gybww { get; set; }/// <summary>/// Desc:/// Default:/// Nullable:True/// </summary> public string csb { get; set; }/// <summary>/// Desc:/// Default:/// Nullable:True/// </summary> public string ztld { get; set; }/// <summary>/// Desc:/// Default:/// Nullable:True/// </summary> public string hdlb { get; set; }/// <summary>/// Desc:/// Default:/// Nullable:True/// </summary> public string hszc { get; set; }/// <summary>/// Desc:/// Default:/// Nullable:True/// </summary> public string hbys { get; set; }/// <summary>/// Desc:/// Default:/// Nullable:True/// </summary> public string cjfl { get; set; }/// <summary>/// Desc:/// Default:/// Nullable:True/// </summary> public string zzql { get; set; }/// <summary>/// Desc:/// Default:/// Nullable:True/// </summary> public string eftx { get; set; }/// <summary>/// Desc:/// Default:/// Nullable:True/// </summary> public string jmc { get; set; }/// <summary>/// Desc:/// Default:/// Nullable:True/// </summary> public string qfzh { get; set; }/// <summary>/// Desc:/// Default:/// Nullable:True/// </summary> public string yxjj { get; set; }/// <summary>/// Desc:/// Default:/// Nullable:True/// </summary> public string yxlw { get; set; }/// <summary>/// Desc:/// Default:/// Nullable:True/// </summary> public string yyyz { get; set; }/// <summary>/// Desc:/// Default:/// Nullable:True/// </summary> public string ccds { get; set; }/// <summary>/// Desc:/// Default:/// Nullable:True/// </summary> public string lbtfz { get; set; }/// <summary>/// Desc:/// Default:/// Nullable:True/// </summary> public string hbzz { get; set; }/// <summary>/// Desc:/// Default:/// Nullable:True/// </summary>public string tgzz { get; set; }/// <summary>/// Desc:/// Default:/// Nullable:True/// </summary>public string hfzz { get; set; }/// <summary>/// Desc:/// Default:/// Nullable:True/// </summary>public string ylzz { get; set; }/// <summary>/// Desc:/// Default:/// Nullable:True/// </summary>public string zfnm { get; set; }/// <summary>/// Desc:/// Default:/// Nullable:True/// </summary>public string qfwzy { get; set; }/// <summary>/// Desc:/// Default:/// Nullable:True/// </summary>public string zszb { get; set; }/// <summary>/// Desc:/// Default:/// Nullable:True/// </summary>public string shmw { get; set; }/// <summary>/// Desc:/// Default:/// Nullable:True/// </summary>public string htdl { get; set; }/// <summary>/// Desc:/// Default:/// Nullable:True/// </summary>public string hbgs { get; set; }/// <summary>/// Desc:/// Default:/// Nullable:True/// </summary>public string xsbl { get; set; }/// <summary>/// alias:/// Default:/// Nullable:True/// </summary> public string alias { get; set; }/// <summary>/// biography1:/// Default:/// Nullable:True/// </summary> public string biography1 { get; set; }/// <summary>/// biography2:/// Default:/// Nullable:True/// </summary> public string biography2 { get; set; }/// <summary>/// biography3:/// Default:/// Nullable:True/// </summary> public string biography3 { get; set; }/// <summary>/// biography3:/// Default:/// Nullable:True/// </summary> public string xiangxing { get; set; }/// <summary>/// biography3:/// Default:/// Nullable:True/// </summary> public string xueyuan { get; set; }/// <summary>/// biography3:/// Default:/// Nullable:True/// </summary> public string fuqin { get; set; }/// <summary>/// biography3:/// Default:/// Nullable:True/// </summary> public string muqin { get; set; }/// <summary>/// biography3:/// Default:/// Nullable:True/// </summary> public string shidai { get; set; }/// <summary>/// biography3:/// Default:/// Nullable:True/// </summary> public string yxd { get; set; }/// <summary>/// biography3:/// Default:/// Nullable:True/// </summary> public string zx { get; set; }/// <summary>/// biography3:/// Default:/// Nullable:True/// </summary> public string zf { get; set; }/// <summary>/// biography3:/// Default:/// Nullable:True/// </summary> public string like1 { get; set; }/// <summary>/// biography3:/// Default:/// Nullable:True/// </summary> public string like2 { get; set; }/// <summary>/// biography3:/// Default:/// Nullable:True/// </summary> public string like3 { get; set; }/// <summary>/// biography3:/// Default:/// Nullable:True/// </summary> public string like4 { get; set; }/// <summary>/// biography3:/// Default:/// Nullable:True/// </summary> public string like5 { get; set; }/// <summary>/// biography3:/// Default:/// Nullable:True/// </summary> public string like6 { get; set; }/// <summary>/// biography3:/// Default:/// Nullable:True/// </summary> public string like7 { get; set; }/// <summary>/// biography3:/// Default:/// Nullable:True/// </summary> public string like8 { get; set; }/// <summary>/// biography3:/// Default:/// Nullable:True/// </summary> public string dislike1 { get; set; }/// <summary>/// biography3:/// Default:/// Nullable:True/// </summary> public string dislike2 { get; set; }/// <summary>/// biography3:/// Default:/// Nullable:True/// </summary> public string dislike3 { get; set; }/// <summary>/// biography3:/// Default:/// Nullable:True/// </summary> public string dislike4 { get; set; }/// <summary>/// biography3:/// Default:/// Nullable:True/// </summary> public string dislike5 { get; set; }/// <summary>/// biography3:/// Default:/// Nullable:True/// </summary> public string dislike6 { get; set; }/// <summary>/// biography3:/// Default:/// Nullable:True/// </summary> public string dislike7 { get; set; }/// <summary>/// biography3:/// Default:/// Nullable:True/// </summary> public string dislike8 { get; set; }public string qingyi { get; set; }public string yexin { get; set; }public string hanchao { get; set; }public string haozhan { get; set; }public string waijiao { get; set; }public string wuzi { get; set; }public string jianshe { get; set; }}
}
(2)在Models文件夹中新建一个MessageModel.cs文件作为通用返回格式:
namespace API.Models
{/// <summary>/// 通用返回信息类/// </summary>public class MessageModel<T>{/// <summary>/// 状态码/// </summary>public int status { get; set; } = 200;/// <summary>/// 页码/// </summary>public int page { get; set; }/// <summary>/// 数据条数/// </summary>public int pageCount { get; set; }/// <summary>/// 操作是否成功/// </summary>public bool success { get; set; } = false;/// <summary>/// 返回信息/// </summary>public string msg { get; set; } = "服务器异常";/// <summary>/// 返回数据集合/// </summary>public T response { get; set; }}
}
(3)在Controllers文件夹里新建DataController.cs文件(新建控制器)
(4)使用sqlsugar这一款ORM框架来进行数据库操作
程序NuGet引入两个类库sqlsugar和Newtonsoft.Json


(5)Controllers文件夹下新建Helper.cs类

Helper.cs全部内容如下:
using SqlSugar;
using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;namespace API.Helper
{public class dbContext{private static SqlSugarClient _db = null;/// <summary>/// test是数据库名/// </summary> public static string ConnectionString = "server=localhost;uid=xxx;pwd=xxx;database=vue_test";public static SqlSugarClient CretClient(){_db = new SqlSugarClient(new ConnectionConfig(){ConnectionString = ConnectionString, //数据库连接字符串DbType = DbType.MySql, //必填IsAutoCloseConnection = false, //默认falseInitKeyType = InitKeyType.Attribute});return _db;}}
}
其中,DbType = DbType.MySql表示我们要连接的数据库为mysql,当然你也可以选择其他的数据库。或者切换多个不同的数据库(具体查看官方文档,既上面的sqlsugar),本篇中只使用一个数据库。server=localhost;uid=xxx;pwd=xxx;database=xxx为连接字符串,这是Mysql的连接字符串样式,不同的数据库是不同的,把里面的xxx换为你自己的数据库用户名,密码,使用的数据库名。
(6)打开我们之前写的DataController.cs文件添加接口方法
首先使用Helper.cs里新建的DbContext类来连接数据库
public static SqlSugarClient DbContext = dbContext.CretClient();

添加引用。此时,当前文件完整引用为:
using Newtonsoft.Json;
using System;
using System.Data;
using System.Data.SqlClient;
using System.Linq;
using System.Net;
using System.Net.Http;
using System.Web.Http;
using MySql.Data.MySqlClient;
using System.Collections;
using System.Text;
using System.Threading.Tasks;
using API.Models;
using System.Collections.Generic;
using System.Web;
using SqlSugar;
using System.Diagnostics;
using System.Reflection;
using API.Helper;
然后添加接口方法,例如添加一个分页查询的方法
/// <summary>/// 获取数据(分页)/// </summary>///<param name="page">当前页数</param>///<param name="intPageSize">每页显示数据条数</param>///<param name="key">查询条件</param>public async Task<MessageModel<object>> GetAsync(int page = 1,int intPageSize=10,string key=""){Expressionable<Data> exp = Expressionable.Create<SanData>();if (!string.IsNullOrEmpty(key)){exp.And(it => it.Name.Contains(key));}var result = DbContext.Queryable<SanData>().Where(exp.ToExpression()).ToPageList(page, intPageSize);return await Task.FromResult(new MessageModel<object>(){status = 200,success = true,msg = "获取成功",response = result});}
3,接口发布
(1)首先打包项目
项目上右键,选择“发布”

点击发布,目标位置里的app.publish文件夹就是我们后台打的包
(2)然后通过IIS发布
如果是新的服务器可能需要启用IIS服务

4,接口调用
注意1:接口在小程序使用之前,应保证可在外网访问。(这可在服务器平台的安全组设置以及服务器的出入口规则设置端口号来实现)
注意2:正式上线的小程序如要访问外网接口,接口必须是绑定在已经备案的域名上;并且,在小程序平台上的开发管理中,将开发设置下的服务器域名配置成你备案的域名。若是在本地微信开发者工具上访问,则先直接访问IP地址加端口号的形式也可以。
这里以获取亲爱/厌恶武将A的数据接口GetAllBeLove为例:
请求url为:BASE_URL /GetAllBeLove
参数有两个,name即武将名称,type即亲爱/厌恶
在小程序中获取数据:
//获取亲爱武将A的数据let name="刘备";let type="like";let result_like = await fetchData(BASE_URL + 'GetAllBeLove', { name, type });//请求数据async function fetchData(url, data = {}) {return new Promise((resolve, reject) => {wx.request({url,data,header: {'content-type': 'application/x-www-form-urlencoded'},method: "GET",success: resolve,fail: reject});});}
获取结果结构如下:

相关文章:
三国志14信息查询小程序(历史武将信息一览)制作更新过程05-后台接口的编写及调用
1,创建ASP.NET Web API项目 生成完毕,项目结构如下: 运行看一下: 2,后台接口编写 (1)在Models文件夹中新建一个sandata.cs文件(就是上篇中武将信息表的model文件) u…...
时序预测 | MATLAB实现基于SVM-Adaboost支持向量机结合AdaBoost时间序列预测
时序预测 | MATLAB实现基于SVM-Adaboost支持向量机结合AdaBoost时间序列预测 目录 时序预测 | MATLAB实现基于SVM-Adaboost支持向量机结合AdaBoost时间序列预测预测效果基本介绍模型描述程序设计参考资料 预测效果 基本介绍 1.Matlab实现SVM-Adaboost时间序列预测(风…...
useEffect和useLayoutEffect的区别
烤冷面加辣条的抖音 - 抖音 (douyin.com) 一、看下面的代码,即使调换useLayoutEffect和useEffect的位置依旧是useLayoutEffect先输出。 import { useState, useEffect, useLayoutEffect } from "react"; const Index () > {useLayoutEffect(() >…...
[科研图像处理]用matlab平替image-j,有点麻烦,但很灵活!
做材料与生物相关方向的同学应该对image-j并不陌生,前几天有个师兄拜托我用image-j分析一些图片,但使用过后发现我由于不了解image-j的工作流程而对结果并不确信,而且image-j的功能无法拓展,对有些图片的处理效果并不好࿰…...
Node.js |(五)包管理工具 | 尚硅谷2023版Node.js零基础视频教程
学习视频:尚硅谷2023版Node.js零基础视频教程,nodejs新手到高手 文章目录 📚概念介绍📚npm🐇安装npm🐇基本使用🐇生产依赖与开发依赖🐇npm全局安装🐇npm安装指定包和删除…...
【ES专题】ElasticSearch集群架构剖析
目录 前言阅读对象阅读导航要点笔记正文一、ES集群架构1.1 为什么要使用ES集群架构1.2 ES集群核心概念1.2.1 节点1.2.1.1 Master Node主节点的功能1.2.1.2 Data Node数据节点的功能1.2.1.3 Coordinate Node协调节点的功能1.2.1.4 Ingest Node协调节点的功能1.2.1.5 其他节点功能…...
Kafka与Flink的整合 -- sink、source
1、首先导入依赖: <dependency><groupId>org.apache.flink</groupId><artifactId>flink-connector-kafka</artifactId><version>1.15.2</version></dependency> 2、 source:Flink从Kafka中读取数据 p…...
小鱼ROS
git clone git clone https://ghproxy.com/https://github.com/stilleshan/ServerStatus git clone 私有仓库 Clone 私有仓库需要用户在 Personal access tokens 申请 Token 配合使用.git clone https://user:your_tokenghproxy.com/https://github.com/your_name/your_priv…...
简单讲讲RISC-V跳转指令基于具体场景的实现
背景 在 RISC-V指令集中,一共有 6 条有条件跳转指令,分别是 beq、bne、blt、bltu、bge、bgeu。如下是它们的定义与接口 BEQ rs1, rs2, imm ≠ BNE rs1, rs2, imm < BLT rs1, rs2, imm ≥ BGE rs1, rs2, imm < unsigned BLTU rs1…...
第13章 Java IO流处理(一) File类
目录 内容说明 章节内容 一、 File类 内容说明 结合章节内容重点难点,会对重要知识点进行扩展,以及做示例说明等,以便更好理解重点难点 章节内容 一、 File类 1、文件与目录的描述类——File ✔️ File类并不用来进行文件的读/写操作,并未涉及到写入或读取文件内容的…...
测试面试题集锦(四)| Linux 与 Python 编程篇(附答案)
本系列文章总结归纳了一些软件测试工程师常见的面试题,主要来源于个人面试遇到的、网络搜集(完善)、工作日常讨论等,分为以下十个部分,供大家参考。如有错误的地方,欢迎指正。有更多的面试题或面试中遇到的…...
pytorch中的矩阵乘法
1. 运算符介绍 关于运算,*运算,torch.mul(), torch.mm(), torch.mv(), tensor.t() 和 *代表矩阵的两种相乘方式: 表示常规的数学上定义的矩阵相乘; *表示两个矩阵对应位置处的两个元素相乘。 1.1 矩阵点乘 *和torch.mul()等同…...
Java--Stream流详解
Stream是Java 8 API添加的一个新的抽象,称为流Stream,以一种声明性方式处理数据集合(侧重对于源数据计算能力的封装,并且支持序列与并行两种操作方式) Stream流是从支持数据处理操作的源生成的元素序列,源可…...
[PHP]ShopXO企业级B2C免费开源商城系统 v2.3.1
ShopXO 企业级B2C免费开源电商系统! 求实进取、创新专注、自主研发、国内领先企业级B2C电商系统解决方案。 遵循Apache2开源协议发布,无需授权、可商用、可二次开发、满足99%的电商运营需求。 PCH5、支付宝小程序、微信小程序、百度小程序、头条&抖音…...
Python基础入门系列详解20篇
Python基础入门(1)----Python简介 Python基础入门(2)----安装Python环境(Windows、MacOS、CentOS、Ubuntu) Python基础入门(3)----Python基础语法:解释器、标识符、关键…...
P02项目(学习)
★ P02项目 项目描述:安全操作项目旨在提高医疗设备的安全性,特别是在医生离开操作屏幕时,以减少非授权人员的误操作风险。为实现这一目标,我们采用多层次的保护措施,包括人脸识别、姿势检测以及二维码识别等技术。这些…...
pandas 笔记:get_dummies分类变量one-hot化
1 函数介绍 pandas.get_dummies 是 pandas 库中的一个函数,它用于将分类变量转换为哑变量/指示变量。所谓的哑变量,就是将分类变量的每一个不同的值转换为一个新的0/1变量。在输出的DataFrame中,每一列都以该值的名称命名 pandas.get_dummi…...
PTE作文练习(一)
目录 65分备考建议 WE模版 范文 Supporting ideas: SWT 65分备考建议 RA重在多听标准的正确的示范,RS重在抓大放小,WFD重在整理错题,以及反反复复的车轮战,FIBRW重在“以对代记” 就是直接看答案,节约时间&#…...
如何做到一套FPGA工程无缝兼容两款不同的板卡?
试想这样一种场景,有两款不同的FPGA板卡,它们的功能代码90%都是一样的,但是两个板卡的管脚分配完全不同,一般情况下,我们需要设计两个工程,两套代码,之后还需要一直维护两个版本。 那么有没有一种自动化的方式,实现一个工程,编译出一个程序文件,下载到这两个不同的板…...
VSCode修改主题为Eclipse 绿色护眼模式
前言 从参加开发以来,一直使用eclipse进行开发,基本官方出新版本,我都会更新。后来出来很多其他的IDE工具,我也尝试了,但他们的主题都把我劝退了,黑色主题是谁想出来?😂 字体小的时…...
脑机新手指南(八):OpenBCI_GUI:从环境搭建到数据可视化(下)
一、数据处理与分析实战 (一)实时滤波与参数调整 基础滤波操作 60Hz 工频滤波:勾选界面右侧 “60Hz” 复选框,可有效抑制电网干扰(适用于北美地区,欧洲用户可调整为 50Hz)。 平滑处理&…...
【JavaEE】-- HTTP
1. HTTP是什么? HTTP(全称为"超文本传输协议")是一种应用非常广泛的应用层协议,HTTP是基于TCP协议的一种应用层协议。 应用层协议:是计算机网络协议栈中最高层的协议,它定义了运行在不同主机上…...
如何在看板中体现优先级变化
在看板中有效体现优先级变化的关键措施包括:采用颜色或标签标识优先级、设置任务排序规则、使用独立的优先级列或泳道、结合自动化规则同步优先级变化、建立定期的优先级审查流程。其中,设置任务排序规则尤其重要,因为它让看板视觉上直观地体…...
iPhone密码忘记了办?iPhoneUnlocker,iPhone解锁工具Aiseesoft iPhone Unlocker 高级注册版分享
平时用 iPhone 的时候,难免会碰到解锁的麻烦事。比如密码忘了、人脸识别 / 指纹识别突然不灵,或者买了二手 iPhone 却被原来的 iCloud 账号锁住,这时候就需要靠谱的解锁工具来帮忙了。Aiseesoft iPhone Unlocker 就是专门解决这些问题的软件&…...
学校招生小程序源码介绍
基于ThinkPHPFastAdminUniApp开发的学校招生小程序源码,专为学校招生场景量身打造,功能实用且操作便捷。 从技术架构来看,ThinkPHP提供稳定可靠的后台服务,FastAdmin加速开发流程,UniApp则保障小程序在多端有良好的兼…...
1.3 VSCode安装与环境配置
进入网址Visual Studio Code - Code Editing. Redefined下载.deb文件,然后打开终端,进入下载文件夹,键入命令 sudo dpkg -i code_1.100.3-1748872405_amd64.deb 在终端键入命令code即启动vscode 需要安装插件列表 1.Chinese简化 2.ros …...
Linux C语言网络编程详细入门教程:如何一步步实现TCP服务端与客户端通信
文章目录 Linux C语言网络编程详细入门教程:如何一步步实现TCP服务端与客户端通信前言一、网络通信基础概念二、服务端与客户端的完整流程图解三、每一步的详细讲解和代码示例1. 创建Socket(服务端和客户端都要)2. 绑定本地地址和端口&#x…...
【Redis】笔记|第8节|大厂高并发缓存架构实战与优化
缓存架构 代码结构 代码详情 功能点: 多级缓存,先查本地缓存,再查Redis,最后才查数据库热点数据重建逻辑使用分布式锁,二次查询更新缓存采用读写锁提升性能采用Redis的发布订阅机制通知所有实例更新本地缓存适用读多…...
华为OD机考-机房布局
import java.util.*;public class DemoTest5 {public static void main(String[] args) {Scanner in new Scanner(System.in);// 注意 hasNext 和 hasNextLine 的区别while (in.hasNextLine()) { // 注意 while 处理多个 caseSystem.out.println(solve(in.nextLine()));}}priv…...
【从零开始学习JVM | 第四篇】类加载器和双亲委派机制(高频面试题)
前言: 双亲委派机制对于面试这块来说非常重要,在实际开发中也是经常遇见需要打破双亲委派的需求,今天我们一起来探索一下什么是双亲委派机制,在此之前我们先介绍一下类的加载器。 目录 编辑 前言: 类加载器 1. …...
