mvc identity连接mysql_asp.net MVC5,如何使用mysql数据库,使用MVC框架中自带的identity用户验证体系...

问题如题

现在很多时候,即使是.net项目,我们用的数据库也未必时是 SQL Server了。

但很多VS 自带的框架(如MVC 、WebAPI等框架)中的示例自带的仍然是默认Sql Server的,而且并不一定好改成别的数据库。这有时候就很苦恼。

比如.net MVC框架中自带的一套用户体系,含有用户登录注册权限角色等一大堆的功能。如果我们开始一个新项目,不得不使用Sql Server以外的数据库的化,而且又没有足够的成本来重新开发一套权限管理机制的话,那我们要怎么办呢?

自己仓促写的通常又太low,也不怎么安全。

套用别的又很麻烦。

而实际上,这种情况在我的工作经历中一直持续发生,到现在我也没能成功地运用好VS .net框架中自带的那一套权限体系,每次都自己开发,但又觉得有点low。

痛定思痛啊,这篇博文就是为了解决这个问题。

这里面提供两种思路和方案。

经尝试,就算我最终在web.config里面把mysql的配置好,项目可以启动,但注册和登录等需要读写数据库的时候还是会出错。

原因很简单,sql server的话,可以直接创建数据库和表,毕竟是自家亲儿子。

别的数据库,比如mysql,就无法创建数据库和表,也就失败了。

table XXX not existed的错误提示很明显了。

于是我就想到了一种低级一点的办法,事实证明,好理解,也有效。

1.低级一点的。

手工按照.net框架里要的那样,建好一个数据库和表,以及对应字段。

如图:

43892da069c2376adf3380d48542a034.png

那么你又要问,到底是什么结构呢? 这多麻烦啊

我的办法是:

用VS新建一个MVC项目,然后就简单粗暴运行,注册等。此时会发现已经有sql server数据库和表生成了。

如图

“视图” – sql server对象管理器“

7b75ba2fc46d04c7d8e857b2706e4d1a.png

然后,

依次获得到各个table的创建语句

1dde8d3d70bbaec20ccc45e9cec42e2a.png

然后就可以看到打开的sql文件里的类似如下的sql语句片段:

USE [aspnet-WebApplication4-20180326090819]

GO

/****** 对象: Table [dbo].[AspNetRoles] 脚本日期: 2018/3/27 11:46:34 ******/

SET ANSI_NULLS ON GO SET QUOTED_IDENTIFIER ON GO CREATE TABLE [dbo].[AspNetRoles] ( [Id] NVARCHAR (128) NOT NULL, [Name] NVARCHAR (256) NOT NULL );

GO

CREATE UNIQUE NONCLUSTERED INDEX [RoleNameIndex] ON [dbo].[AspNetRoles]([Name] ASC);

GO

ALTER TABLE [dbo].[AspNetRoles] ADD CONSTRAINT [PK_dbo.AspNetRoles] PRIMARY KEY CLUSTERED ([Id] ASC);

可以用来创建mysql中的表吗?

机智哦

不过直接粘贴过去执行还是会报错的,毕竟是不同的数据库,数据类型、语法什么的还是有些不一样。

我们就取其中的

CREATE TABLE [dbo].[AspNetRoles] ( [Id] NVARCHAR (128) NOT NULL, [Name] NVARCHAR (256) NOT NULL );

创建表的这句话去mysql中建表就行了。

再相应修改一下:

CREATE TABLE AspNetRoles ( Id VARCHAR (128) NOT NULL, Name VARCHAR (256) NOT NULL );

如上,我去掉了dbo,去掉了中括号,NVARCHAR改为VARCHAR。

然后在mysql中执行,真的就成功了。

所以,另外的几个表,以此类推,在mysql中就可以得到几个表,结构和字段与sql server中的都一致了。

这些我已经亲测了,确实成功。

而且后续的运行,注册,登录等都可以成功。

不再赘述。

总之,这里算是耍了个滑头。

但也算是解决了问题,毕竟能用。

但上述方法真的好勉强啊。

问题的关键其实很简单,就是在现有代码条件下,mysql没法直接就创建了mysql table这些东西。

如果能呢,那岂不是很好?

这也就是我后来终于找到的

2. 高级一点的做法

我本机的环境:

windows 10 64bit

Visual Studio 2015 旗舰版,.NET 4.5.2,

Mysql 5.7.17 社区版。

按照博文中的配置好之后,直接运行成功,一字不改。

而且注册登录都成功写入数据库。

完全仿照这个做完就好了。

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

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

相关文章

Dapr 知多少 | 分布式应用运行时

IntroDapr 官方团队已于最近(2021.2.17)正式发布Dapr v1.0,Dapr已正式生产可用,可以部署到自托管环境或 Kubernetes 集群。对于绝大多数开发者来说,想必对Dapr只是有所耳闻,而具体是什么(What&a…

使用.NET中的XML注释(一) -- XML注释标签讲解

一.摘要 .Net允许开发人员在源代码中插入XML注释,这在多人协作开发的时候显得特别有用。 C#解析器可以把代码文件中的这些XML标记提取出来,并作进一步的处理为外部文档。 这篇文章将展示如何使用这些XML注释。 在项目开发中,很多人并不乐意写…

pythonpil库过滤图像contour_一秒钟带你走进P图世界-----(python)PIL库的使用

python-----PIL库的使用一、什么是PIL库1.PIL(Python Image Library)库是python语言的第三方库,具有强大的图像处理能力,不仅包含了丰富的像素、色彩操作功能,还可以用于图像的归档和批量处理能力。2.PIL库主要有2个方面的功能:(1…

mysql tddl_TDDL思考总结

单机数据库分布式数据库TDDL原理与最佳实践1. 数据库的结构1.1. KV存储(id是K)1.2. B树与红黑树B树的特点是叶子节点是块状,一个叶子里面有多个数据,相邻数据是存在一起的,123,456起等,而磁盘也是按块的,B树…

c# winform中窗体切换后释放及防止重复生成

问题1:窗体切换后如何关闭,并释放资?c# winform中,2个窗体,form1和form2,互相切换的时候执行this.Hide(); Form2 form2 new Form2();form2.Show();此时你会发现当Form2显现时,Form1隐藏了,但当你关闭Form2时,其进程并…

2018程序员必备碎片化学习工具(年度精选)

2017马上就要过去了,2018来了。工作、生活节奏超快的今天,想要不断提升自我,碎片化阅读学习是你最佳的选择,如果你有一颗学习的心,那这些学习型的公众号,绝对会让你受益匪浅。小编为你精选了技术领域几个精…

mfc 找到字符串中字符_[LeetCode] 467. 环绕字符串中唯一的子字符串

题目链接: https://leetcode-cn.com/problems/unique-substrings-in-wraparound-string难度:中等通过率:35.6%题目描述:把字符串 s 看作是"abcdefghijklmnopqrstuvwxyz"的无限环绕字符串,所以 s 看起来是这样的&#xf…

ntopng mysql_网络流量监控工具与分析Ntop和Ntopng

Ntop工具NtopNtop是一种监控网络流量工具,用ntop显示网络的使用情况比其他一些网络管理软件更加直观、详细。Ntop甚至可以列出每个节点计算机的网络带宽利用率。Ntop工作方式1. 命令行界面2. web界面Ntop的功能1. 可以自动从网络中获取有用的信息2. 可以将获取的数据…

oracle express介绍

Oracle express 不是一种新型火车也不是一种新型的邮递服务。Oracle express是个多维的数据库和应用程序环境,这个应用程序环境是用来构建OLAP应用程序的。Express的组件(或者OLAP选项)是维(多维部分中的一部分)和变量…

一文读懂背包问题

转自:刘毅https://www.61mon.com/index.php/archives/188/问题展开有 N 件物品和一个容量为 V 的背包。第 i 件物品的体积是 Ci,其价值是 Wi。求解,在不超过背包容量情况下,将哪些物品装入背包可使价值总和最大。基本思路这是最基…

python核心数据类型_Python核心数据类型——列表

列表列表是任意对象的有序集合。也就是说,其元素可以是任何类型的对象。有序指的是,有严格的从左到右的顺序,这一点不同于字典,可以通过偏移读取,支持在原处修改,长度可变,是可变的类型。1. 常…

java io操作_Java 的IO操作(文件的读,写操作)

/* * FileEditor.java * * Created on 2006年9月13日, 下午2:22 * * To change this template, choose Tools | Template Manager * and open the template in the editor. */ /** *这是第一个类,没有利用缓冲技术 */ package fileeditor; import java.io.*;…

小米造车是智能手机进入红海后的突围之举

日前,媒体报道小米已确定造车,并视其为战略级决策。此前,雷静曾多次考虑造车,但未下定决心,而是选择了投资蔚来和小鹏,而且并未占多少股权,小米在两家公司上市时的持股份额均不到 5%&#xff0c…

linux服务之NIS

NIS服务RHEL4系统中NIS服务器软件的名称是ypserv,该软件包没有被系统默认安装,需要手动安装系统中的ypbind软件包是NIS客户端需要使用的软件包,yp-tools软件包中提供了对NIS服务器的查询和管理工具软件,这两个包是RHEL4系统中默认…

群论的创立:两个少年天才的接力

我们生活的世界中,美丽的对称无处不在。不过喜欢认死理的数学家,则硬要用他们独特的语言来定义对称。在数学上,对称与群相关联。随着数论、代数方程和几何等研究方向的发展,“群论”这个无比重要的数学领域被开创建立。而这一伟大…

python oracle连接池_【Python + Oracle】Python Oracle连接池—改进版

Oracle 连接池第四版。编程语言Python语言版本3.5.3实现功能oracle 连接池,解决频繁连接oracle数据库带来的连接资源耗费问题程序托管GitHub-OraclePool修改日期2020年8月3日version 4.0 改进说明:**[2020-04-21]** 修复连接用完后,不放回连接…

为什么有些大公司的技术弱爆了?

阅读本文大概需要5分钟。最近好几个大厂的读者不约而同跟我聊到公司采用的技术栈很落后的问题,一个读者还感叹:是不是大厂的领导都是混子?技术这么弱还不如之前呆的小公司。回复了几个读者朋友之后,这里也想跟大家分享下这个问题&…

普通程序员转型深度学习指南

AI领域人才奇缺,炙手可热的AI专业应届生年薪30万起步,AI毕业生基本不用找工作,都已经被企业早早预定。AI人才究竟有多紧缺?据腾讯研究院《全球人工智能人才白皮书》报告数据,目前全球AI领域人才仅约30万,全…

sm缩写代表什么意思_pe、PE在电气有代表什么意思,你发现没有,电气技术很有意思...

pe、pe、pe这些是什么意思解说1,听小课堂电小二跟你讲PE是Protecting Earthing的缩写,简体中文名称称之为“保护导体”,也就是我们通常所说的“地线”,我国规定PE线为黄绿双色线 。1.PE线的应用PE线是专门用于将电气装置外露导电部…

java短信接口 调用_带你了解短信接口的调用

查看接口说明image.png注册账号注册成功的页面如下:image.png设置短信内容的签名比如:将短信签名设置为yzcimage.png查取短信接口密钥image.png设计Java程序短信发送客户端的代码如下:package day02;import org.apache.http.Header;import or…