当我试图从数据库中检索数据时,我会得到一个Object reference not set to an instance of an object
错误。我知道EF有一个dbcontext,我可以使用,但是我想尝试这种方法,因为我的同事使用这种方法。我可以得到ConnectionString罚款,我看到它在我的断点,但在这一行之后,我得到了错误:
System.Configuration.ConnectionStringSettingsCollection.thisstring.get
返回null
我的代码如下:
appsettings.json
"AllowedHosts": "*",
"ConnectionStrings": {
"DefaultConnection": "Server=DESKTOP-MIHT9TM\\SQLEXPRESS;Database=react_db;User=sa;Password=OtlPHP07"
}
Startup.cs
public void ConfigureServices(IServiceCollection services)
{
services.AddControllers();
services
.AddMvc(options =>
{
options.EnableEndpointRouting = false;
})
.AddNewtonsoftJson()
.SetCompatibilityVersion(CompatibilityVersion.Version_3_0)
.AddJsonOptions(options =>
{
options.JsonSerializerOptions.IgnoreNullValues = true;
options.JsonSerializerOptions.WriteIndented = true;
});
services.AddSingleton<IConfiguration>(Configuration);
}
DepartmentController.cs
[Route("api/[controller]")]
[ApiController]
public class DepartmentController : ControllerBase
{
private readonly IConfiguration configuration;
public DepartmentController(IConfiguration configuration)
{
this.configuration = configuration;
}
[HttpGet]
public IActionResult Get()
{
DataTable table = new DataTable();
string query = @"SELECT * FROM dbo.Departments";
var conString = configuration.GetConnectionString("DefaultConnection");
using (var con = new SqlConnection(ConfigurationManager.ConnectionStrings[conString].ConnectionString))
{
using (var cmd = new SqlCommand(query, con))
{
using (var da = new SqlDataAdapter(cmd))
{
cmd.CommandType = CommandType.Text;
da.Fill(table);
}
}
}
return Ok(table);
}
}
我在这一行中遇到了错误:using (var con = new SqlConnection(ConfigurationManager.ConnectionStrings[conString].ConnectionString))
编辑
这是conString的值
我甚至试过这个密码..。
var conString = configuration.GetConnectionString("DefaultConnection");
using (var con = new SqlConnection(ConfigurationManager.AppSettings[conString].ToString()))
发布于 2020-05-17 06:20:46
在SqlConnection上,尝试使用传递给构造函数的配置对象,而不是它的新实例。或者更好的是您已经拥有的conString变量(它确实使用传递给构造函数的配置实例)
https://stackoverflow.com/questions/61847644
复制相似问题