三国志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工具,我也尝试了,但他们的主题都把我劝退了,黑色主题是谁想出来?😂 字体小的时…...
Vim 调用外部命令学习笔记
Vim 外部命令集成完全指南 文章目录 Vim 外部命令集成完全指南核心概念理解命令语法解析语法对比 常用外部命令详解文本排序与去重文本筛选与搜索高级 grep 搜索技巧文本替换与编辑字符处理高级文本处理编程语言处理其他实用命令 范围操作示例指定行范围处理复合命令示例 实用技…...

观成科技:隐蔽隧道工具Ligolo-ng加密流量分析
1.工具介绍 Ligolo-ng是一款由go编写的高效隧道工具,该工具基于TUN接口实现其功能,利用反向TCP/TLS连接建立一条隐蔽的通信信道,支持使用Let’s Encrypt自动生成证书。Ligolo-ng的通信隐蔽性体现在其支持多种连接方式,适应复杂网…...

业务系统对接大模型的基础方案:架构设计与关键步骤
业务系统对接大模型:架构设计与关键步骤 在当今数字化转型的浪潮中,大语言模型(LLM)已成为企业提升业务效率和创新能力的关键技术之一。将大模型集成到业务系统中,不仅可以优化用户体验,还能为业务决策提供…...

黑马Mybatis
Mybatis 表现层:页面展示 业务层:逻辑处理 持久层:持久数据化保存 在这里插入图片描述 Mybatis快速入门 
聊聊 Pulsar:Producer 源码解析
一、前言 Apache Pulsar 是一个企业级的开源分布式消息传递平台,以其高性能、可扩展性和存储计算分离架构在消息队列和流处理领域独树一帜。在 Pulsar 的核心架构中,Producer(生产者) 是连接客户端应用与消息队列的第一步。生产者…...
蓝桥杯 2024 15届国赛 A组 儿童节快乐
P10576 [蓝桥杯 2024 国 A] 儿童节快乐 题目描述 五彩斑斓的气球在蓝天下悠然飘荡,轻快的音乐在耳边持续回荡,小朋友们手牵着手一同畅快欢笑。在这样一片安乐祥和的氛围下,六一来了。 今天是六一儿童节,小蓝老师为了让大家在节…...
vue3 定时器-定义全局方法 vue+ts
1.创建ts文件 路径:src/utils/timer.ts 完整代码: import { onUnmounted } from vuetype TimerCallback (...args: any[]) > voidexport function useGlobalTimer() {const timers: Map<number, NodeJS.Timeout> new Map()// 创建定时器con…...

C# 类和继承(抽象类)
抽象类 抽象类是指设计为被继承的类。抽象类只能被用作其他类的基类。 不能创建抽象类的实例。抽象类使用abstract修饰符声明。 抽象类可以包含抽象成员或普通的非抽象成员。抽象类的成员可以是抽象成员和普通带 实现的成员的任意组合。抽象类自己可以派生自另一个抽象类。例…...
WEB3全栈开发——面试专业技能点P2智能合约开发(Solidity)
一、Solidity合约开发 下面是 Solidity 合约开发 的概念、代码示例及讲解,适合用作学习或写简历项目背景说明。 🧠 一、概念简介:Solidity 合约开发 Solidity 是一种专门为 以太坊(Ethereum)平台编写智能合约的高级编…...

UR 协作机器人「三剑客」:精密轻量担当(UR7e)、全能协作主力(UR12e)、重型任务专家(UR15)
UR协作机器人正以其卓越性能在现代制造业自动化中扮演重要角色。UR7e、UR12e和UR15通过创新技术和精准设计满足了不同行业的多样化需求。其中,UR15以其速度、精度及人工智能准备能力成为自动化领域的重要突破。UR7e和UR12e则在负载规格和市场定位上不断优化…...