使用 WCF 创建需要身份验证并使用 JSON 作为输入/输出格式的 RESTful Web 服务

发布于 2024-11-07 06:46:20 字数 702 浏览 5 评论 0原文

我想将现有的 ASP.NET Web 服务移植到 WCF,以便生成的 Web 服务 (1) 是 RESTful,(2) 使用 JSON 作为其请求/响应格式,(3) 具有自定义身份验证机制。

经过大量的谷歌搜索、随机编码以及想把头撞到墙上之后,我发现...

  1. 必须使用 webHttpBinding 来使 Web 服务 RESTful。但是...

    1. webHttpBinding 不支持 HTTPS 主机。

    2. webHttpBinding 不支持用户名身份验证。

    3. webHttpBinding 甚至不支持消息安全性。

  2. 必须使用 的端点行为来支持 ASP.NET AJAX。但是...

    1. 什么是“ASP.NET”AJAX?

    2. 如果我想使用“常规”AJAX 使用 Web 服务怎么办?

而且,最重要的是...

  1. WCF 可以做我想做的事情吗?

  2. 如果没有,我还可以使用哪些其他平台?

I want to port an existing ASP.NET Web Service to WCF so the resulting Web Service (1) is RESTful, (2) uses JSON as its request/response format, (3) has a custom authentication mechanism.

After a lot of googling, random coding, and wanting to hit my head against the wall, I found that...

  1. A webHttpBinding has to be used to make the Web Service RESTful. But...

    1. webHttpBinding does not support HTTPS hosts.

    2. webHttpBinding does not support UserName authentication.

    3. webHttpBinding does not even support message security.

  2. An endpoint behavior with <enableWebScript/> has to be used to support ASP.NET AJAX. But...

    1. What is "ASP.NET" AJAX?

    2. What if I want to consume the Web Service using "regular" AJAX?

And, most importantly...

  1. Can WCF do what I want to do in first place?

  2. If not, what other platforms could I use?

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(2

ζ澈沫 2024-11-14 06:46:20

我编写了 WCF 服务,它使用 XML 和 JSON 以及自定义身份验证执行 SOAP 和 REST。我已将自定义身份验证推送到 HTTP 模块中,该模块通过 https 进行基本身份验证。请参阅自定义.NET 3.5/VS 2008 上的 ASP.NET Web 服务的 HTTP 基本身份验证WCF POX、JSON 和 SOAP 共存

I've written WCF service that does both SOAP and REST with XML and JSON, and custom auth. I've pushed the custom authentication into HTTP module, which does basic auth over https. See Custom HTTP Basic Authentication for ASP.NET Web Services on .NET 3.5/VS 2008 and WCF POX, JSON and SOAP Coexist.

无法回应 2024-11-14 06:46:20

在您描述的设置中,Web 服务器(即 IIS)将负责加密(HTTPS)和身份验证(例如基本身份验证)。 IIS 可以使用自定义身份验证机制进行扩展(只需在 google 中搜索“IIS 模块处理程序”)。

有点奇怪的是它必须委托给 IIS 并且不是 WCF 的一部分。但这完全没有问题。

In the setup you describe, the web servier (i.e. IIS) will be responsible for encryption (HTTPS) and authentication (e.g. basic authentiction). IIS can be extended with a custom authentication mechanism (just google for "IIS module handler").

It's a bit strange that it has to be delegated to IIS and is not part of WCF. But it's no problem at all.

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文