修改WCF数据服务5.6中的connectionString

时间:2015-01-07 19:28:26

标签: c# wpf oracle odata wcf-data-services

我正在使用Oracle DataAccess(最后一个),里面有很多数据库用户。所以,我想在我的客户端应用程序(WPF)中创建connectionString并将其传递给服务器。我正在服务器上执行以下操作:

protected override POSContext CreateDataSource()
{
    HttpRequest req = HttpContext.Current.Request;

    if (req.Headers != null && Array.FindIndex(req.Headers.AllKeys, c=>c.Equals("db", StringComparison.OrdinalIgnoreCase)) > 0)
    {
        string database = req.Headers["db"]; 
        string user = req.Headers["user"];
        string pass = req.Headers["pass"];

        StringBuilder conexion = new StringBuilder();
        conexion.Append("DATA SOURCE=");
        conexion.Append(database);
        conexion.Append(";USER ID=");
        conexion.Append(user);
        conexion.Append(";PASSWORD=");
        conexion.Append(pass);

        if (!string.IsNullOrEmpty(conexion.ToString()))
            return new POSContext(conexion.ToString());
    }

    return null;//new POSContext();
}  

在客户端中,我有以下代码:

var context = new POS.DataServices.POSContext(new Uri(Storage.Current.UrlService)); // Something like this http://localhost/POService.svc
context.BuildingRequest += (s, args) => //Or SendingRequest2 produces the same result
{
    args.Headers.Add("db", Storage.Current.Configuraciones.DB);
    args.Headers.Add("user", Storage.Current.Configuraciones.UserName);
    args.Headers.Add("pass", Storage.Current.Configuraciones.Password);
};

MessageBox.Show(proxy.POS_CIUDAD.ToList().FirstOrDefault().CIU_DESC); //Alert the city name  

当我调试我的应用程序时,我有一个错误(请求错误)。我的客户端代码首先尝试显示消息,然后转到BuildingRequest。如何在实体调用之前传递connectionString?

1 个答案:

答案 0 :(得分:0)

CreateDataSource在服务启动时被调用一次,这就是你在那里得到错误的原因。

我认为您可以尝试以下方法:

  1. 在POSContext上添加连接字符串属性,并为POSContext提供无参数构造函数。这是连接字符串可以稍后设置。也许您需要确保仅在连接字符串准备好时才设置连接。
  2. 覆盖OnStartProcessingRequest方法,并更改CurrentDataSource(POSContext类)上的连接字符串