Gridview配置数据源--信任服务器证书
目录
- 背景
- 过程
- Gridview配置数据源
- GridView与数据源:
- 数据库连接与安全:
- 信任服务器证书:
- 配置信任服务器证书:
- 注意事项:
- 生成连接字符串
- 程序运行报错
- 问题解决
- 总结
背景
Gridview配置数据源之后,程序报错
过程
Gridview配置数据源
信任服务器证书,这里如果不勾选,会报错
GridView与数据源:
GridView是Web开发中常用的数据展示控件,它可以从多种数据源(如数据库、XML文件、对象集合等)中获取数据,并以表格形式显示。
配置数据源是指将GridView与特定的数据提供程序(如SqlDataSource、ObjectDataSource等)或数据源连接字符串相关联的过程。
数据库连接与安全:
当GridView通过数据库连接字符串连接到数据库时,可能会涉及到网络安全问题。
在使用SSL/TLS加密的数据库连接中,客户端(如Web应用程序)和服务器(如数据库服务器)之间的通信会被加密,以保护敏感数据不被窃取或篡改。
信任服务器证书:
在建立SSL/TLS加密的数据库连接时,服务器会向客户端提供一个证书,以证明其身份。
“信任服务器证书”意味着客户端(或更具体地说,是运行GridView的Web应用程序)接受并信任服务器提供的证书。
如果证书是有效的(即由受信任的证书颁发机构签发,且未过期、未撤销),则连接可以安全地继续。
如果证书存在问题(如自签名证书、证书过期、证书颁发机构不受信任等),则客户端可能会拒绝连接,或者要求用户确认是否继续(这取决于具体的配置和应用程序的行为)。
配置信任服务器证书:
在某些情况下,特别是使用自签名证书或内部证书颁发机构时,可能需要在客户端上配置信任。
这通常涉及将服务器的证书导入到客户端的信任存储中,或者在连接字符串中指定信任服务器的选项(这取决于具体的数据库驱动程序和连接字符串格式)。
注意事项:
信任自签名证书或不受信任的证书颁发机构签发的证书可能会带来安全风险,因为它削弱了SSL/TLS加密提供的安全性保证。
在生产环境中,应尽可能使用由受信任的证书颁发机构签发的证书,并确保证书的有效性和安全性。
生成连接字符串
在SQL Server连接字符串中,使用TrustServerCertificate=true来绕过证书验证(但请注意,这会降低安全性)。
看下这段代码
Server=localhost;Initial Catalog=newsystem;Integrated Security=True;TrustServerCertificate=True;
Server=localhost:指定服务器的地址,这里是本地主机。
Initial Catalog=newsystem:指定要连接的数据库名称。
Integrated Security=True:指定使用Windows身份验证来连接数据库。这意味着不需要提供用户名和密码,而是依赖Windows用户帐户的凭据。
Trus tServer Certificate=True:指定客户端应该信任服务器的SSL证书,即使该证书不是由受信任的证书颁发机构签发的。这通常用于开发或测试环境,但在生产环境中可能会带来安全风险。
程序运行报错
开头展示的那张图片
在生产环境中,应该确保服务器使用由受信任的证书颁发机构签发的有效SSL证书,并将TrustServerCertificate设置为False(或完全省略该参数,因为False是默认值)。
问题解决
项目中,删除这段话
重新生成解决方案,成功运行
原因分析:(可能原因–证书问题)
Gridview配置数据源时的“信任服务器证书”选项:
在图形化界面工具或向导中,用于配置数据库连接。当勾选这个选项时,它通常会在生成的连接字符串中包含TrustServerCertificate=True。这个参数的作用是告诉客户端(我的应用程序)信任服务器的SSL证书,即使该证书不是由受信任的证书颁发机构签发的。
服务器可能使用了一个不受客户端信任的SSL证书。
证书可能已经过期、被撤销或存在其他问题。
客户端(应用程序)无法验证服务器的身份,因为证书链不完整或证书颁发机构不受信任。
当 TrustServerCertificate=True 被设置时,客户端会忽略证书验证错误,并继续建立连接。删除此参数后,客户端将执行正常的证书验证,如果证书有问题,连接将失败。
删除此参数是遵循最佳安全实践的做法,确保只有使用有效和受信任证书的服务器才能被连接。
总结
图形化界面中的任何选择都会以某种形式映射到代码层面,无论是配置文件、数据库连接字符串,还是应用程序内部的逻辑。因此,当在图形化界面中做出选择(如勾选“信任服务器证书”)后遇到问题时,需要深入代码层面去寻找问题的根源。
相关文章:

Gridview配置数据源--信任服务器证书
目录 背景过程Gridview配置数据源GridView与数据源:数据库连接与安全:信任服务器证书:配置信任服务器证书:注意事项: 生成连接字符串程序运行报错问题解决 总结 背景 Gridview配置数据源之后,程序报错 过…...

【Next.js 入门教程系列】08-发送邮件
原文链接 CSDN 的排版/样式可能有问题,去我的博客查看原文系列吧,觉得有用的话, 给我的库点个star,关注一下吧 上一篇【Next.js 入门教程系列】07-身份验证 发送邮件 Setting Up React Email React Email 是一个高效便捷的 E…...

Echarts合集更更更之树图
实现效果 写在最后🍒 源码,关注🍥苏苏的bug,🍡苏苏的github,🍪苏苏的码云...

线性代数 行列式
一、行列式 1、定义 一个数学概念,主要用于 线性代数中,它是一个可以从方阵(即行数和列数相等的矩阵)形成的一个标量(即一个单一的数值) 2、二阶行列式 ,像这样将一个式子收缩称为一个 2*2 的…...
Ubuntu 通过 Docker 搭建 GitLab
准备工作 1.)更新软件。确保你的系统是最新 sudo apt update sudo apt upgrade -y 2.)安装 Docker 和 Docker Compose。 参考:Ubuntu 上安装 Docker-CSDN博客 1. 创建 GitLab 目录 创建一个用于存储 GitLab 数据和配置的目录࿱…...

原来CDC数据同步可以这么简单,零代码可视化一键数据同步
当前企业实时同步与分析场景中面临的挑战: 随着业务发展需要,实时分析成为企业目前的强需求,成为支撑企业业务发展的必须项。 一般来说,要满足数据实时分析的诉求,通常有两种方案: 第一种是直接使用源端…...
Ubuntu环境使用 Whisper 与 ZhipuAI 实现本地批量视频转录与文本标点复原(本地亲测可用)
使用 Whisper 与 ZhipuAI 实现批量视频转录与文本标点添加 在本篇博客中,我们将介绍一个实用的项目,帮助初学者了解如何使用 Whisper 和 ZhipuAI 的 API 来进行视频转录和文本处理。这个项目主要功能是将视频转录成文本,并利用大语言模型为转…...
SPI机制
一、SPI简介 SPI(Service Provider Interface)机制是一种服务发现机制,广泛用于Java生态中。它允许框架或库通过接口解耦具体实现,用户可以在运行时动态地提供接口的实现,而不是在编译时确定。这种机制在很多场景下非…...

生信分析流程:从数据准备到结果解释的完整指南
介绍 生物信息学(生信)分析是一个复杂的过程,涉及从数据准备到结果解释的多个步骤。随着高通量测序技术的发展和生物数据的迅猛增长,了解和掌握生信分析的标准流程变得尤为重要。这不仅有助于提高分析的准确性,还能优…...
golang语法
参考链接:https://www.runoob.com/go/ 创建变量 // 3种方法 var a int a : 10 // 类型推断 a : make() // 复合类型循环 // 3种循环 for i : 0; i < 10; i {// 循环体} // 传统for循环 for index, num : range nums {// 循环体} // nums是可迭代的复合类型…...

【fisco学习记录2】多群组搭建
说明 文档参考: 多群组部署 — FISCO BCOS 2.0 v2.11.0 文档 (fisco-bcos-documentation.readthedocs.io) 多群组搭建之前,先暂停之前的单群组,并删除: cd fisco bash nodes/127.0.0.1/stop_all.sh rm -rf nodes/ 实现图&…...
深度解读:路由交换、负载均衡与防火墙的网络交响
一、路由交换:网络流动的“大动脉” 1. 路由:决定命运的“路径规划师” 路由技术如同现代交通网络中的导航系统,决定了数据从起点到终点的最佳路径。路由器基于网络层IP地址,对每个数据包进行精确的路径选择,并确保其…...

linux线程 | 线程的控制(二)
前言: 本节内容是线程的控制部分的第二个小节。 主要是列出我们的线程控制部分的几个细节性问题以及我们的线程分离。这些都是需要大量的代码去进行实验的。所以, 准备好接受新知识的友友们请耐心观看。 现在开始我们的学习吧。 ps:本节内容适合了解线程…...

npm install报错一堆sass gyp ERR!
执行npm install ,出现一堆gyp含有sass错误的情况下。 解决办法: 首页可能是node版本问题,太高或者太低,也会导致npm install安装错误(不会自动生成node_modules文件),本次试验,刚开…...
微知-BlueField DPU在lspci中显示Flash Recovery是什么意思?
效果: lspci |grep BlueField10:00.0 Memory controller: Mellanox Technologies MT42822 Family [BlueField-2 SoC Flash Recovery] (rev 01)*原因: 表示此时flash是empty空的,或者在flash中的FW是无法工作的。比如烧录错误。 这里指的一提…...
【前端知识点】前端笔记
css 引入css文件的文件路径 <!-- 引入外部 CSS 文件 --> <!-- 当前文件所在文件夹目录 --> <link rel"stylesheet" href"./"> <!-- 当前文件所在父文件夹目录 --> <link rel"stylesheet" href"../">j…...
Sping Cache 使用详解
缓存是提升应用性能的常用手段。它通过将耗时的操作结果存储起来,下次请求可以直接从缓存中获取,从而避免重复计算或查询数据库,显著减少响应时间和服务器负载。Spring 框架提供了强大的缓存抽象 Spring Cache,它简化了缓存的使用…...
动手学深度学习60 机器翻译与数据集
1. 机器翻译与数据集 import os import torch from d2l import torch as d2l#save d2l.DATA_HUB[fra-eng] (d2l.DATA_URL fra-eng.zip,94646ad1522d915e7b0f9296181140edcf86a4f5)#save def read_data_nmt():"""载入“英语-法语”数据集"&qu…...
Python网络爬虫技术
Python网络爬虫技术详解 引言 网络爬虫(Web Crawler),又称网络蜘蛛(Web Spider)或网络机器人(Web Robot),是一种按照一定规则自动抓取互联网信息的程序或脚本。它们通过遍历网页链…...

黑马程序员-redis项目实践笔记1
目录 一、 基于Session实现登录 发送验证码 验证用户输入验证码 校验登录状态 Redis代替Session登录 发送验证码修改 验证用户输入验证码 登录拦截器的优化 二、 商铺查询缓存 缓存更新策略 数据库和缓存不一致解决方案 缓存更新策略的最佳实践方案 实现商铺缓…...

突破不可导策略的训练难题:零阶优化与强化学习的深度嵌合
强化学习(Reinforcement Learning, RL)是工业领域智能控制的重要方法。它的基本原理是将最优控制问题建模为马尔可夫决策过程,然后使用强化学习的Actor-Critic机制(中文译作“知行互动”机制),逐步迭代求解…...

Qt/C++开发监控GB28181系统/取流协议/同时支持udp/tcp被动/tcp主动
一、前言说明 在2011版本的gb28181协议中,拉取视频流只要求udp方式,从2016开始要求新增支持tcp被动和tcp主动两种方式,udp理论上会丢包的,所以实际使用过程可能会出现画面花屏的情况,而tcp肯定不丢包,起码…...

《Qt C++ 与 OpenCV:解锁视频播放程序设计的奥秘》
引言:探索视频播放程序设计之旅 在当今数字化时代,多媒体应用已渗透到我们生活的方方面面,从日常的视频娱乐到专业的视频监控、视频会议系统,视频播放程序作为多媒体应用的核心组成部分,扮演着至关重要的角色。无论是在个人电脑、移动设备还是智能电视等平台上,用户都期望…...
逻辑回归:给不确定性划界的分类大师
想象你是一名医生。面对患者的检查报告(肿瘤大小、血液指标),你需要做出一个**决定性判断**:恶性还是良性?这种“非黑即白”的抉择,正是**逻辑回归(Logistic Regression)** 的战场&a…...
ssc377d修改flash分区大小
1、flash的分区默认分配16M、 / # df -h Filesystem Size Used Available Use% Mounted on /dev/root 1.9M 1.9M 0 100% / /dev/mtdblock4 3.0M...

为什么需要建设工程项目管理?工程项目管理有哪些亮点功能?
在建筑行业,项目管理的重要性不言而喻。随着工程规模的扩大、技术复杂度的提升,传统的管理模式已经难以满足现代工程的需求。过去,许多企业依赖手工记录、口头沟通和分散的信息管理,导致效率低下、成本失控、风险频发。例如&#…...
生成 Git SSH 证书
🔑 1. 生成 SSH 密钥对 在终端(Windows 使用 Git Bash,Mac/Linux 使用 Terminal)执行命令: ssh-keygen -t rsa -b 4096 -C "your_emailexample.com" 参数说明: -t rsa&#x…...
linux 下常用变更-8
1、删除普通用户 查询用户初始UID和GIDls -l /home/ ###家目录中查看UID cat /etc/group ###此文件查看GID删除用户1.编辑文件 /etc/passwd 找到对应的行,YW343:x:0:0::/home/YW343:/bin/bash 2.将标红的位置修改为用户对应初始UID和GID: YW3…...
【服务器压力测试】本地PC电脑作为服务器运行时出现卡顿和资源紧张(Windows/Linux)
要让本地PC电脑作为服务器运行时出现卡顿和资源紧张的情况,可以通过以下几种方式模拟或触发: 1. 增加CPU负载 运行大量计算密集型任务,例如: 使用多线程循环执行复杂计算(如数学运算、加密解密等)。运行图…...
MySQL账号权限管理指南:安全创建账户与精细授权技巧
在MySQL数据库管理中,合理创建用户账号并分配精确权限是保障数据安全的核心环节。直接使用root账号进行所有操作不仅危险且难以审计操作行为。今天我们来全面解析MySQL账号创建与权限分配的专业方法。 一、为何需要创建独立账号? 最小权限原则…...