【C#】生成WebAPI实现简单调用本地数据库

news2024/10/3 2:25:02

需求:通过C#生成WebAPI,供微信小程序调用以访问本地数据库(微信小程序部分下次再说,今天先记录一下C#生成WebAPI相关的坑与注意点)。

数据库:SQL Server

Web服务器:IIS

编程语言:C#

IDE:VS2019 

准备工作:配置安装IIS

注意事项:不要一次性全勾完,否则很有可能安装失败。

建议先找到.NET Framework 勾选默认复选框,等其安装完成(这个过程需要联网支持下载文件)后再安装IIS。

Tip:命令行输入 inetmgr 可以快速切到 IIS

添加网点,配置虚拟目录即可。( 因为 80、8080为常用的端口,所以我配置IIS时端口就默认 1114 。)

参考资料:

win10安装配置IIS的教程_泊云V的博客-CSDN博客_win10iis

c#配置安装IIS管理器_是五月吖的博客-CSDN博客_c# iis

HTTP 错误 500.19 - Internal Server Error 无法访问请求的页面,因为该页的相关配置数据无效。

HTTP 错误 500.19 - Internal Server Error 无法访问请求的页面,因为该页的相关配置数据无效。"解决方法..._chubosheng0951的博客-CSDN博客

(3条消息) 【学习笔记】IIS 部署webApi 报500.19 解决方法_没什么好听名字的博客-CSDN博客

一、创建WebAPI

注意事项:框架要选到4.5

这里值得多提一句,MVC项目可以用MVC5控制器,WebAPI项目推荐选择Web API 2控制器。如果不确定怎么写可以先选 -空 后面再添加EF数据实体。

 本地服务器输入 . 即可

对数据实体操作

  直接查找整个表

 public IHttpActionResult Getem() 
        {
            var list = db.SAP_EMPBAS.ToList();//直接查找整个表
            return Json(list);
        }

参考资料:

C# 搭建一个简单的WebApi项目_YuanlongWang的博客-CSDN博客_c# webapi项目

C# WebAPI创建及具体实现_FenfsfDensting的博客-CSDN博客_webapi创建

vs2019 添加ado数据模型步骤_fighting18的博客-CSDN博客

【2021-04-11】VS2019添加新建项,没有 ADO.NET实体数据模型_六月雨的皮卡丘的博客-CSDN博客

VS2017用EF+WebApi做一个简单的增删改查_氏张的博客-CSDN博客

二、发布

注意事项:不要删除现有文件

接下来可以选择测试工具postman,不过我们写的比较简单,所以选IE浏览器(Microsoft Edge)输个url就差不多可以看出效果了。

正常运行界面如下。

之前查找整个表数据的Getem(这里api是固定的,因为我生成的是API控制器,后面的EmpBas是我创建的控制器名称,最后一个是刚写的Get接口)

接着是传一个简单参数的接口:

        [HttpGet]
        [Route("api/EmpBas/Getom")]
        public IHttpActionResult Getom(string Empyno)
        {
            var list = db.SAP_EMPBAS.Where(a=>a.EMPYNO==Empyno);
            return Json(list);
        }

发布后的效果

 

最后,项目源码见主页下载资源(仅供参考,很多都是官方自带的设定)

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/7320.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

微信|零到一打造一款与微信互通的自动聊天机器人应用

本文干货充足篇幅较长,建议收藏后阅读避免迷路。文末可获取【自动聊天机器人源码和Demo】。 本教程教大家使用即构 ZIM SDK 创建一个能与微信端互动消息的自动聊天机器人应用。ZIM SDK可广泛应用于娱乐社交、电商购物、在线教育、互动直播等多种场景下即时通讯功能实…

R语言中的函数18:readxl::read_excel(), read_xls(),read_xlsx()

文章目录read_excel(), read_xls()和read_xlsx()函数介绍实例实例1利用read_xls读取文件实例2指定读取数据的范围range实例3读取有缺失值的数据实例4read_xls和read_xlsx需要对应的文件类型实例5read_excel的使用read_excel(), read_xls()和read_xlsx()函数介绍 read_excel(),…

设计模式----单例模式

设计模式之单例模式 文章目录设计模式之单例模式一. 简介1. 什么是单例模式?2. 单例模式的应用场景?3. 单例模式的类型?二. 单例模式的几种写法1. 饿汉式2. 懒汉式3. 懒汉式(线程安全性能优化)4. 使用volatile防止指令…

【ARM】Bootloader的调试

Bootloader 为啥要做一个bootloader,因为最近客户调试MCU中,中断向量表和代码不设置一个区域内,在0x0的地址放置中断向量表,并在0x18000000的地址放置代码,发现会有一点问题,想测试一下在0x18000000的地址…

Linux C/C++异常处理方法

简介 C/C属于较为接近底层的语言,不像Java等“高级”语言,所有异常都能catch住(例如常见的core dumped)异常: int first_func() {int* error_integer nullptr;return *error_integer; } 对于异常,首要任…

传统 Web 框架部署与迁移

与其说 Serverless 架构是一个新的概念,不如说它是一种全新的思路,一种新的编程范式。 但是原生的 Serverless 开发框架却非常少。以 Web 框架为例,目前主流的 Web 框架“均不支持 Serverless 模式部署”,因此我们一方面要尝试接…

跳槽or裸辞?2022年真不建议···

2022年是个“难过”的一年。 疫情、经济寒冬、房价跳水、基金股票一片红。其实这些都是连锁反应。 企业不好过,也会引发一系列裁人潮,其实最近挺多小伙伴反映过,今年过的如牛马,一人干活量顶仨。想辞职躺平,又没有绝…

BurpSuit官方实验室之信息泄露

BurpSuit官方实验室之信息泄露 这是BurpSuit官方的实验室靶场,以下将记录个人信息泄露共5个Lab的通关过程 Web Security Academy: Free Online Training from PortSwigger lab1: Information disclosure in error messages 错误消息中的信息泄露 在…

从金鸡百花电影节,看“鼓浪屿元宇宙”的元力、魅力与想象力

文|智能相对论 作者|青月 元宇宙的走红,始于2021年3月10日Roblox在美上市,这个和现实世界相平行又相交叉的虚拟世界开始引起市场的注意,并迅速风靡全球。 虽然2022年,关于元宇宙的探索已经进入了一个相对务实的阶段&#xff0c…

【毕业设计】机器视觉停车位识别检测系统 - python 深度学习

文章目录1 简介2 检测效果3 实现方式3.1 整体思路3.2 检测空车位3.3 车辆识别4 最后1 简介 🔥 Hi,大家好,这里是丹成学长的毕设系列文章! 🔥 对毕设有任何疑问都可以问学长哦! 这两年开始,各个学校对毕设…

【面试题】「2023」JavaScript 最新高频 前端面试题 指南 (必看)

前言 大家好,本次总结了关于JavaScript的上百道高频面试考点,感谢大家的留言点赞收藏 💗 如果文中有不对、疑惑或者错字的地方,欢迎在评论区留言指正🌻 更多题库 地址:前端面试题库 基础篇 1. 将数组的…

【微前端开发环境下,加载远程子应用的实战。】

一开始我们的本地开发运行的环境,如果没有启动子应用的话。对应的页面是白屏的。 问题: 当有关联资源需要跳转时无法跳转,需要额外打开一个浏览器tab页到环境上面执行操作。当bug类型为纯ui-server端的内容时,需要手动启动bug相关…

【数据库原理及应用】——事务并发控制和恢复技术(学习笔记)

📖 前言:事务是数据库操作的基本逻辑单元,事务处理技术主要包括数据库并发控制技术和恢复技术。本章首先介绍了事务的基本概念和四个特性,然后讨论事务并发操作可能引起数据库的不一致性,继而引入数据库的并发控制技术…

Compare线刷包与卡刷包

Android系统分为卡刷包和线刷包 小米11线刷包 从该版本的boot.img中抽取出的内容如下图 小米11卡刷包 从该版本的boot.img中可以提取的内容是 也就是说,想要做配置文件抽取需要用线刷包。经过测试,目前高版本的卡刷包通过解压都无法获取到boot.img…

图像分割 - 阈值处理 - 固定阈值法

目录 1. 介绍 2. 固定阈值处理 1. 介绍 图像分割就是将图像分成不同的区域,每个区域满足相似的条件。通常,都是将图像分为两个区域:前景区域和背景区域。 前景就是人们感兴趣的位置,例如一副Lena图像,我们只对这副图…

Redis-Mysql八股总结

Redis 说一下 Redis以及Redis 使用场景 答:Redis 是一种基于内存的数据库,对数据的读写操作都是在内存中完成,因此读写速度非常快,常用于缓存,消息队列、分布式锁等场景。 Redis 设置过期时间的命令 # 设置 key 在…

上网行为监控都能审计到哪些内容?

现在很多企业都部署了上网行为监控系统,那么,它可以审计到哪些内容呢?目前市面上有不同种类的上网行为监控系统,其功能都是大同小异的,这里我们以墨门云为例,了解一下装了这个软件之后管理者可以审计到哪些…

WPF探究【一】

文章目录WPF的概述:控件分类XAML对象元素语法XAML根元素WPF和XAML命名空间声明控件Lablel示例继承关系TextBlockbuttonBorderWPF的概述: WindowsPresentationFoundation(简称WPF)WPF的核心是一个与分辩率无关且基于实量的呈现引擎…

【深入理解Kotlin协程】使用Job控制协程的生命周期

Job 是协程上下文CoroutineContext的实现之一,通过它我们可以对协程的生命周期进行一些控制操作。Job 是协程的句柄。使用 launch 或 async 创建的每个协程都会返回一个 Job 实例对象,该实例是相应协程的唯一标识并管理其生命周期。还可以将 Job 传递给 …

数据结构与算法(四) 广度优先搜索

本篇文章继续来学习广度优先搜索算法(Broad-First-Search,BFS) 1、本质 广度优先搜索本质上还是遍历整个搜索空间,找到给定问题的解 实际上也是一种暴力搜索算法,不过其中的实现细节和优化细节还是值得探讨的 与深度…