我想为我的客户创建一个 Web 服务,以便他们可以在自己的网站上显示他们的数据。由于我不知道每个客户端正在运行什么平台,因此创建可供所有浏览器使用的 WCF 服务代理的最佳解决方案是什么?另外,我不确定应该如何呈现数据。假设我的用户没有任何开发技能。我将通过其他一些界面,让用户能够下载创建请求所需的代码,然后处理响应。在客户端解析 xml 响应然后创建数据列表或已格式化列表(以字符串形式)并让客户端执行 document.write 会更好吗?我看过一些解决方案,但它们似乎需要使用带有脚本管理器的 ASP 页面。就像我说的,我想要一些足够通用的东西来使用不同的浏览器。主要是IE和FireFox。

丹尼尔

有帮助吗?

解决方案

首先,由于您不想依赖 Microsoft Ajax ScriptManager,因此不要在端点Behaviors/behavior 中使用 <enableWebScript />。它是 Microsoft 特定的 JSON。

但幸运的是,WCF 使您的客户端可以轻松决定是否需要 XML 还是通用 JSON。

  1. 使用 <webHttp/> 行为。

    <端点行为>
    <行为名称=“My.WcfServices.webHttpBehavior”>
    <webHttp/>
    </行为>
    </端点行为>

  2. 创建自定义 WebServiceHost 和自定义属性属性,如中所述Damian Mehers 的博客,WCF REST 服务. 。在 Mehers 的代码中,类型由请求内容类型决定。您可能希望扩展它以检查 URL,例如 .xml 或 .json 或 ?format=xml|json。

  3. 在里面 序列化回复 方法,检查 URL。

    消息请求 = OperationContext.Current.RequestContext.RequestMessage;
    Uri url = request.Properties["OriginalHttpRequestUri"] as Uri;
    // 检查 ?format 查询字符串
    System.Collections.Specialized.NameValueCollection colQuery = System.Web.HttpUtility.ParseQueryString(url.Query);
    字符串 strResponseFormat = colQuery["格式"];
    // 或检查扩展
    字符串 strResponseFormat = url.LocalPath.Contains(".json") ?“json”:“XML”;

  4. 定义你的方法

    【运营合同】
    [WebGet(UriTemplate="Hello.{responseFormat}")] // 或 "Hello?format={responseFormat}"
    [动态响应类型]
    公共字符串你好(字符串响应格式)
    {
    返回“你好世界”;
    }

示例 URL:
http://localhost/myrest.svc/Hello.xml
http://localhost/myrest.svc/Hello.json
或者
http://localhost/myrest.svc/Hello?format=xml
http://localhost/myrest.svc/Hello?format=json

  1. JSON 和 XML 都很容易跨浏览器使用。诸如用于 JSON 的 jQuery 和用于 XML 的 Sarissa 等库使这一切变得更加容易。

笔记:如果您看到错误“无法找到与绑定 WebHttpBinding 的端点的方案 http 相匹配的基地址。”,请添加 基本地址前缀过滤器 元素并将 localhost(或任何您的域)添加到 IIS 主机标头名称。

<system.serviceModel>
<serviceHostingEnvironment aspNetCompatibilityEnabled="true">
    <baseAddressPrefixFilters>
        <add prefix="http://localhost"/>
    </baseAddressPrefixFilters>
</serviceHostingEnvironment>
许可以下: CC-BY-SA归因
不隶属于 StackOverflow
scroll top