RError.com

RError.com Logo RError.com Logo

RError.com Navigation

  • 主页

Mobile menu

Close
  • 主页
  • 系统&网络
    • 热门问题
    • 最新问题
    • 标签
  • Ubuntu
    • 热门问题
    • 最新问题
    • 标签
  • 帮助
主页 / 问题 / 1424755
Accepted
Danila
Danila
Asked:2022-08-28 21:24:00 +0000 UTC2022-08-28 21:24:00 +0000 UTC 2022-08-28 21:24:00 +0000 UTC

为什么响应体是空的?

  • 772

如果正确输入了登录名和密码,我编写了一个返回所有用户数据的身份验证。这里一切都很好。数据库管理器文件代码:

public static User AuthUser(User user)
    {
        if (sqlConnection.State == System.Data.ConnectionState.Closed)
            sqlConnection.Open();
        try
        {
            SqlCommand command = new SqlCommand(
                $"SELECT * FROM [Users] WHERE login = @login AND password = @password",
                sqlConnection);
            command.Parameters.AddWithValue("login", user.login);
            command.Parameters.AddWithValue("password", user.password);

            SqlDataReader reader = command.ExecuteReader();
            if (reader.Read())
            {
                user.id = Convert.ToInt32(reader.GetValue(0));
                user.lastName = Convert.ToString(reader.GetValue(1));
                user.firstName = Convert.ToString(reader.GetValue(2));
                user.patronymic = Convert.ToString(reader.GetValue(3));
                user.phoneNumber = Convert.ToString(reader.GetValue(4));
                user.address = Convert.ToString(reader.GetValue(5));
                user.role = (Role)Convert.ToInt16(reader.GetValue(8));
            }
                sqlConnection.Close();
                return user;
        }
        catch
        {
            sqlConnection.Close();
            return user;
        }
    }

用户控制器文件代码:

[HttpPost("~/Authentication")]
    public User Authentication(string login, string password)
    {
        return DataBaseManager.AuthUser(
            new User(login, password));
    }

它返回: 在此处输入图像描述

接下来,我想接收运输公司的所有信息,但实际上,将参数传递给我没有任何意义。数据库管理器文件代码:

public static SDEK GetInfoSDEK(SDEK sdek)
    {
        if (sqlConnection.State == System.Data.ConnectionState.Closed)
            sqlConnection.Open();
        try
        {
            SqlCommand command = new SqlCommand(
                $"SELECT * FROM [TransportCompanies] WHERE name = @name",
                sqlConnection);
            command.Parameters.AddWithValue("name", sdek.name);

            SqlDataReader reader = command.ExecuteReader();
            if (reader.Read())
            {
                sdek.id = Convert.ToInt32(reader.GetValue(0));
                sdek.price_km = Convert.ToDecimal(reader.GetValue(2));
                sdek.price_kg = Convert.ToDecimal(reader.GetValue(3));
                sdek.price_insurance = Convert.ToDecimal(reader.GetValue(4));
            }
            sqlConnection.Close();
            return sdek;
        }
        catch
        {
            sqlConnection.Close();
            return sdek;
        }
    }

TransportCompanyController 文件代码:

[HttpGet("~/GetInfoSDEK")]
    public SDEK GetInfoSDEK()
    {
        return DataBaseManager.GetInfoSDEK(new SDEK());
    }

回报: 在此处输入图像描述

我要求它返回一个 SDEK 类的实例,但它没有。我通过调试检查了它 - 它写入并查看所有数据。SDEK 类作为库包含(通过分配)。

问题:我做错了什么?

更新:“显示用户和 SDEK 数据模型”

用户型号:

    namespace DeliveryApp
{
    public enum Role
    {
        User,
        Admin
    }
    public class User
    {
        public int id { get; set; }
        public string lastName { get; set; }
        public string firstName { get; set; }
        public string patronymic { get; set; }
        public string phoneNumber { get; set; }
        public string address { get; set; }
        public string login { get; set; }
        public string password { get; set; }
        public Role role { get; set; }


        public User(string lastName, string firstName, string patronymic, string phoneNumber, string address, string login, string password, Role role = Role.User)
        {
            this.lastName = lastName;
            this.firstName = firstName;
            this.patronymic = patronymic;
            this.phoneNumber = phoneNumber;
            this.address = address;
            this.login = login;
            this.password = password;
            this.role = role;
        }
        public User(string login, string password)
        {
            this.login = login;
            this.password = password;
        }
    }
}

SDEK 型号:

namespace TransportCompany1
{
    public class SDEK
    {
        public int id = -1;
        public string name = "SDEK";
        public decimal price_km = 0;
        public decimal price_kg = 0;
        public decimal price_insurance = 0;

        public SDEK(int id, string name, decimal price_km, decimal price_kg, decimal price_insurance) // СЕРВЕР: Отвечает клиенту, если такая транспортная компания существует.
        {
            this.id = id;
            this.name = name;
            this.price_km = price_km;
            this.price_kg = price_kg;
            this.price_insurance = price_insurance;
        }
        public SDEK() { }
    }
}
c# api
  • 1 1 个回答
  • 26 Views

1 个回答

  • Voted
  1. Best Answer
    aepot
    2022-08-28T21:29:36Z2022-08-28T21:29:36Z

    请注意,在类中,User您有属性

    public int id { get; set; }
    

    在课堂上SDEK你有领域

    public int id = -1;
    

    为了使模型序列化,需要属性

    public int id { get; set; } = -1;
    
    • 1

相关问题

Sidebar

Stats

  • 问题 10021
  • Answers 30001
  • 最佳答案 8000
  • 用户 6900
  • 常问
  • 回答
  • Marko Smith

    我看不懂措辞

    • 1 个回答
  • Marko Smith

    请求的模块“del”不提供名为“default”的导出

    • 3 个回答
  • Marko Smith

    "!+tab" 在 HTML 的 vs 代码中不起作用

    • 5 个回答
  • Marko Smith

    我正在尝试解决“猜词”的问题。Python

    • 2 个回答
  • Marko Smith

    可以使用哪些命令将当前指针移动到指定的提交而不更改工作目录中的文件?

    • 1 个回答
  • Marko Smith

    Python解析野莓

    • 1 个回答
  • Marko Smith

    问题:“警告:检查最新版本的 pip 时出错。”

    • 2 个回答
  • Marko Smith

    帮助编写一个用值填充变量的循环。解决这个问题

    • 2 个回答
  • Marko Smith

    尽管依赖数组为空,但在渲染上调用了 2 次 useEffect

    • 2 个回答
  • Marko Smith

    数据不通过 Telegram.WebApp.sendData 发送

    • 1 个回答
  • Martin Hope
    Alexandr_TT 2020年新年大赛! 2020-12-20 18:20:21 +0000 UTC
  • Martin Hope
    Alexandr_TT 圣诞树动画 2020-12-23 00:38:08 +0000 UTC
  • Martin Hope
    Air 究竟是什么标识了网站访问者? 2020-11-03 15:49:20 +0000 UTC
  • Martin Hope
    Qwertiy 号码显示 9223372036854775807 2020-07-11 18:16:49 +0000 UTC
  • Martin Hope
    user216109 如何为黑客设下陷阱,或充分击退攻击? 2020-05-10 02:22:52 +0000 UTC
  • Martin Hope
    Qwertiy 并变成3个无穷大 2020-11-06 07:15:57 +0000 UTC
  • Martin Hope
    koks_rs 什么是样板代码? 2020-10-27 15:43:19 +0000 UTC
  • Martin Hope
    Sirop4ik 向 git 提交发布的正确方法是什么? 2020-10-05 00:02:00 +0000 UTC
  • Martin Hope
    faoxis 为什么在这么多示例中函数都称为 foo? 2020-08-15 04:42:49 +0000 UTC
  • Martin Hope
    Pavel Mayorov 如何从事件或回调函数中返回值?或者至少等他们完成。 2020-08-11 16:49:28 +0000 UTC

热门标签

javascript python java php c# c++ html android jquery mysql

Explore

  • 主页
  • 问题
    • 热门问题
    • 最新问题
  • 标签
  • 帮助

Footer

RError.com

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

帮助

© 2023 RError.com All Rights Reserve   沪ICP备12040472号-5