当前位置: 首页 > news >正文

C#使用实体类Entity Framework Core操作mysql入门:从数据库反向生成模型2 处理连接字符串

初级代码游戏的专栏介绍与文章目录-CSDN博客

我的github:codetoys,所有代码都将会位于ctfc库中。已经放入库中我会指出在库中的位置。

这些代码大部分以Linux为目标但部分代码是纯C++的,可以在任何平台上使用。

源码指引:github源码指引_初级代码游戏的博客-CSDN博客


        本文接上一篇:C#使用实体类Entity Framework Core操作mysql入门:从数据库反向生成模型-CSDN博客

一、连接字符串在生成代码里

        上一篇我们已经完成了基本操作,但是有一个问题,连接字符串被原样写入了生成的上下文代码里,代码是这样的:

    protected override void OnConfiguring(DbContextOptionsBuilder optionsBuilder)
#warning To protect potentially sensitive information in your connection string, you should move it out of source code. You can avoid scaffolding the connection string by using the Name= syntax to read it from configuration - see https://go.microsoft.com/fwlink/?linkid=2131148. For more guidance on storing connection strings, see https://go.microsoft.com/fwlink/?LinkId=723263.=> optionsBuilder.UseMySQL("server=???;userid=???;pwd=???;port=3306;database=???;sslmode=none;allowPublicKeyRetrieval=true;");

        因为这是不安全的操作,所以代码里面直接给了一个警告,并给了官方指引。

        官方建议的方案是用配置参数,但是使用配置参数需要支持配置参数的项目,而我的项目是个类库,并不是asp.net或应用程序,所以不能使用配置参数。

        除了安全原因,如果修改了数据库需要重新生成,或者修改了数据库参数,都要修改源代码也是不可接受的,所一定要想办法解决。

二、不生成连接参数

        虽然不能使用配置参数,不过仍有解决方案,而且更通用:用-NoOnConfiguring参数来阻止生成这个方法。在命令行最后增加这个参数,生成的代码就不会有上面的这个方法。

        仔细对比一下发现,生成的代码不仅没有了OnConfiguring方法,也没有了默认构造函数,从而必须手动提供参数才行,下面是修改后的测试代码:

			{DbContextOptionsBuilder<库名Context> optionsBuilder =new ();optionsBuilder.UseMySQL("server=???;userid=???;pwd=???;port=3306;database=???;sslmode=none;allowPublicKeyRetrieval=true;");using var db = new 库名Context(optionsBuilder.Options);var records = db.表名;foreach (var item in records){Log(item.col1);}}

        这个方法提供了完全的自由度。


(这里是文档结束)

http://www.lryc.cn/news/463486.html

相关文章:

  • Go语言基础学习(Go安装配置、基础语法)·
  • 高德开放平台API调用实战指南
  • 文档太大LLM处理不过来?这10种LangChain分割技术帮你搞定!
  • TikTok广告账号被封?常见原因及解决方法分享
  • maven聚合ssm
  • 网络通信与并发编程(二)基于tcp的套接字、基于udp的套接字、粘包现象
  • 400行程序写一个实时操作系统(十):用面向对象思想构建抢占式内核
  • C#学习笔记(九)
  • 意外发现!AI写作这样用,热点文章轻松超越同行90%!
  • WPF常见容器全方位介绍
  • 重置时把el-tree树节点选中状态取消
  • 服务器系统克隆技术
  • 【Java】多线程 Start() 与 run() (简洁实操)
  • 基于微信小程序的购物系统【附源码、文档】
  • AI绘画:24最新Stable Diffusion 终极炼丹宝典:从入门到精通!
  • 线性可分支持向量机的原理推导【补充知识部分】拉格朗日函数 公式解析
  • csdn(最新交流群)
  • 新手maven入门学习教程
  • React 中级阶段学习计划
  • [产品管理-47]:产品市场调研 - 一级市场、二级市场、次级市场?
  • Linux零基础教程学习(黑马)
  • 一款零依赖、跨平台的流媒体协议处理工具,支持 RTSP、WebRTC、RTMP 等视频流协议的处理
  • PHP 正则验证A-Z且排除某字母
  • 如何安全运行别人上传的Python代码?
  • matlab相位图
  • C语言笔记(指针的进阶)
  • NodeJS连接MySQL 8.4报错:code: ‘ER_TABLEACCESS_DENIED_ERROR‘
  • 力扣66~70题
  • Axure重要元件三——中继器添加数据
  • 矩阵系统哪家好~矩阵短视频运营~怎么矩阵OEM