c# - ASP.NET Web API 本地主机 :xxxx/api/product defaults to Home Page and not JSON data(orXML)

标签 c# mysql json asp.net-web-api sql-server-express

我正在尝试通过 API 将数据从 SQLEXPRESS 数据库提取到我的客户端 UWP 应用程序。

这是我的代码(因此思考):

API Controller :

[Route("api/product")]

public class ProductController : ApiController
{
    // GET: api/product
    [HttpGet]
    public ObservableCollection<Product> Get() 
    {
        string userId = "newuser"; //for testing only

        return Model.ReadAllSQLProducts(userId);
    }
}

型号:

// R part of CRUD
    public static ObservableCollection<Product> ReadAllSQLProducts(string userId)
    {
        var connString = "Server=localhost\\SQLEXPRESS;Integrated Security = SSPI; database = myDbName";
        string cmdText = "Select * FROM Product WHERE CONVERT(VARCHAR, UserId) = @userId;";
        using (var sqlConnection = new SqlConnection(connString))
        {
            using (var sqlCmd = new SqlCommand(cmdText, sqlConnection))
            {
                List<Product> SQLProductList = new List<Product>();

                sqlConnection.Open();

                SqlParameter param = new SqlParameter();
                param.ParameterName = "@userId";
                param.Value = userId;
                sqlCmd.Parameters.Add(param);
                SqlDataReader reader = sqlCmd.ExecuteReader();

                while (reader.Read())
                {
                    Product sqlProduct = new Product();
                    sqlProduct.UserId = (string)reader["UserId"];
                    sqlProduct.Name = (string)reader["Name"];
                    sqlProduct.Category = (string)reader["Category"];
                    SQLProductList.Add(sqlProduct);

                }
                List<Product> myCollection = SQLProductList.ToList();
                ObservableCollection<Product> dbSQLProductsList = new ObservableCollection<Product>(myCollection);
                return dbSQLProductsList;
            }
        }
    }

这是客户端如何消费的(至少按照我遵循的教程:

using (var client = new HttpClient())
        {
            var response = "";
            Task task = Task.Run(async () =>
            {
                response = await client.GetStringAsync(App.BaseUri); // sends GET request
            });
            task.Wait(); // Wait
            listViewAPI.ItemsSource = JsonConvert.DeserializeObject<ObservableCollection<Product>>(response); // Bind the list
        }

App.BaseUri 是:

        public static Uri BaseUri = new Uri("http://localhost:58834/api/Product/"); // base API URL; UserController

所以,我必须说这是我第一次尝试使用 API。 客户端最初依赖于 SQLite,它的工作方式就像一个魅力。在后期我决定与 MySQL 同步。我设法让它在客户端应用程序中工作。 但是,我想将所有 SQL 相关代码移至 API 中。该 API 不仅可以为 UWP 应用程序提供服务,还可以为 Android 和 iOS(Xamarin.Forms) 提供服务。

API URL 返回 ASP.NET 主页。显然,API 无法从数据库获取数据,并且客户端应用程序没有可用的 JSON 数据。

我做错了什么>???

(作为补充 - 所有 SQL 相关代码都可以在客户端正常运行)

最佳答案

我做了几件事让我的 Controller 正常工作: 1. 我创建了新 Controller ,而不是重命名现有 Controller (在项目创建时创建的 Controller )。这很重要,因为该项目为每个 Controller 创建了新的 Views 文件夹,没有该文件夹它将无法工作,并且它还具有其他一些使 Controller 工作的魔力。 2. 在 Global.asax.cs 文件中,我重新排序了内容,使其按以下(正确)顺序排列:

 AreaRegistration.RegisterAllAreas();
 GlobalConfiguration.Configure(WebApiConfig.Register);
 FilterConfig.RegisterGlobalFilters(GlobalFilters.Filters);
 RouteConfig.RegisterRoutes(RouteTable.Routes);
 BundleConfig.RegisterBundles(BundleTable.Bundles);

3.在 Web.config 中我添加了 runAllManagedModulesForAllRequests="true"<modules/> <system.webServer>内.

就是这样。 API 正常工作,SQL 数据通过 HttpGet 传递到客户端应用程序。

我花了 12 个多小时才修复它。

关于c# - ASP.NET Web API 本地主机 :xxxx/api/product defaults to Home Page and not JSON data(orXML),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/51526980/

相关文章:

python - 无法将 numpy 数组转换为 JSON

c# - 值对象是否应该持有对实体的引用?

python - 如何从字典列表中修改字典的值

c# - mysql语法错误?

php - 按日期排序(最新)

mysql - SQL 使用两个子查询

python - 调用包含 API 调用的类和函数时没有返回值

ios - 如何使用数组和内部更多 JSON 来解码 JSON?

c# - UWP - 防止 NavigationViewItemHeader 被剪裁

c# - 如何下载内存流文件