- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我已经编写了我的第一个 Web 服务,当我在我的本地开发机器上从 visual studio 测试运行它时,一切都按预期工作。我去客户端部署服务,发现部署后我可以到达端点,但我的所有方法都返回 HTTP 404 not found。
Web 服务是使用 WCF 在 Visual Studio 中编写的,并设置为返回 Json。 Web 服务的目标是 .Net framework 4.5。该站点配置为使用 HTTPS 协议(protocol)并具有有效的 SSL 证书。我已经使用最新版本的 .Net framework 4.5 更新了服务器,并相应地向站点应用了一个应用程序池。
当我从外部浏览器转到客户端服务器上的端点位置时(我修改了屏幕截图和链接以删除真实域):
链接看起来像这样:
https://www.somedomain.co.uk/WorksWebService/WorksWebService.svc
我得到的页面显示了指向 WSDL 和 SingleWSDL 页面的 Web 服务链接,它们正确地显示了端点方法和各种其他配置信息。
在我看来,一切都符合预期,但我有点不确定下一步该去哪里寻找问题。
现在我很不确定 Web.config 文件的要求是什么。下面是 Web 服务的当前 Web.config 文件。可能是我在这里遗漏了有关服务部署的重要信息,但想知道为什么服务在 Visual Studio 中成功运行?唯一需要注意的区别是,在 visual studio 中,我使用 http 而不是 https 运行服务。
<?xml version="1.0"?>
<configuration>
<appSettings>
<add key="aspnet:UseTaskFriendlySynchronizationContext" value="true" />
</appSettings>
<system.web>
<compilation debug="true" targetFramework="4.5" />
<httpRuntime targetFramework="4.5"/>
</system.web>
<connectionStrings>
<add name="BAXISQL"
connectionString="Database=SomeDatabase;Server=SomeServer;User ID=user;Password=password"
providerName="System.Data.SqlClient"
/>
</connectionStrings>
<system.serviceModel>
<services>
<service name="WorksWebService.WorksWebService">
<endpoint address="" behaviorConfiguration="restful" binding="webHttpBinding"
contract="WorksWebService.IWorksWebService" />
</service>
</services>
<behaviors>
<serviceBehaviors>
<behavior>
<!-- To avoid disclosing metadata information, set the values below to false before deployment -->
<serviceMetadata httpGetEnabled="true" httpsGetEnabled="true"/>
<!-- To receive exception details in faults for debugging purposes, set the value below to true. Set to false before deployment to avoid disclosing exception information -->
<serviceDebug includeExceptionDetailInFaults="false"/>
</behavior>
</serviceBehaviors>
<endpointBehaviors>
<behavior name="restful">
<webHttp/>
</behavior>
</endpointBehaviors>
</behaviors>
<protocolMapping>
<add binding="basicHttpsBinding" scheme="https" />
</protocolMapping>
<serviceHostingEnvironment aspNetCompatibilityEnabled="true" multipleSiteBindingsEnabled="true" />
</system.serviceModel>
<system.webServer>
<modules runAllManagedModulesForAllRequests="true"/>
<!--
To browse web app root directory during debugging, set the value below to true.
Set to false before deployment to avoid disclosing web app folder information.
-->
<directoryBrowse enabled="true"/>
</system.webServer>
<startup>
<supportedRuntime version="4.0" sku=".NETFramework,Version=v4.0"/>
</startup>
</configuration>
我想我的问题来自 Web.config 文件或我的服务接口(interface)和方法声明中缺少的一些元数据。
以下代码显示了我的接口(interface)(修改后只包含一个方法):
using System.IO;
using System.ServiceModel;
using System.Web.Services;
namespace WorksWebService
{
[ServiceContract]
interface IWorksWebService
{
[OperationContract]
[WebMethod]
string GetTrainingStatus(string urn, string pastdays, string futuredays);
}
}
下面是WebService.svc.cs文件中相应的方法调用(也修改为仅显示单个方法):
using System;
using System.Collections.Generic;
using System.Collections;
using System.Data.SqlClient;
using System.Net;
using System.ServiceModel.Web;
using System.Web;
using Newtonsoft.Json;
using System.Runtime.Serialization;
using System.IO;
using System.ServiceModel;
using System.Text;
using Newtonsoft.Json.Linq;
namespace WorksWebService
{
public class WorksWebService: IWorksWebService
{
// key that all methods must receive in the header to validate that the request is from a valid source
private string baxiSMSKey = "C5A75B32-5BC9-4D89-AB78-F8FE0CF58806";
//BAXI_SMS_KEY: C5A75B32-5BC9-4D89-AB78-F8FE0CF58806
#region TrainingStatus
// test url string
// WorksWebService.svc/rest/member/C211292/trainingstatus?country=GB
/// <summary>
/// Method to find the training status dates for a specific Customer
/// </summary>
/// <param name="urn"></param>
/// <param name="country"></param>
/// <returns>Last valid training status date or future date the customer will be attending training</returns>
[WebInvoke(Method = "GET", ResponseFormat = WebMessageFormat.Json
, UriTemplate = "rest/member/{urn}/trainingstatus?pastdays={pastdays}&futuredays={futuredays}")]
public string GetTrainingStatus(string urn, string pastdays, string futuredays)
{
string dateString = string.Empty;
WebOperationContext context = WebOperationContext.Current;
// check the headers for the BAXI_SMS_KEY
if (CheckAPIKey())
{
// validate the url parameters
if (ValidateURLStringParameters_GetTrainingStatus(urn, pastdays, futuredays))
{
// find the training status
dateString = GetTrainingDate(urn, pastdays, futuredays);
if (dateString.Contains("Error: "))
context.OutgoingResponse.StatusCode = HttpStatusCode.InternalServerError; // HTTP Code 500
else if (dateString.Equals(string.Empty))
context.OutgoingResponse.StatusCode = HttpStatusCode.NotFound; // HTTP Code 404
else
context.OutgoingResponse.StatusCode = HttpStatusCode.OK; // HTTP Code 200
}
else
context.OutgoingResponse.StatusCode = HttpStatusCode.BadRequest; // HTTP Code 400
}
else
context.OutgoingResponse.StatusCode = HttpStatusCode.Forbidden; // HTTP Code 403
return dateString;
}
/// <summary>
/// method to validate the parameters for GetTrainingStatus Web method
/// </summary>
/// <param name="urn"></param>
/// <param name="pastdays"></param>
/// <param name="futuredays"></param>
/// <returns>True or False</returns>
private bool ValidateURLStringParameters_GetTrainingStatus(string urn, string pastdays, string futuredays)
{
if (string.IsNullOrWhiteSpace(urn))
return false;
if (string.IsNullOrWhiteSpace(pastdays))
return false;
if (string.IsNullOrWhiteSpace(futuredays))
return false;
try
{
Convert.ToInt32(pastdays);
Convert.ToInt32(futuredays);
}
catch (Exception e)
{
return false;
}
return true;
}
/// <summary>
/// Method to find the training status of the member
/// </summary>
/// <param name="urn"></param>
/// <returns>the date of the users training past of future</returns>
private string GetTrainingDate(string urn, string pastdays, string futuredays)
{
string dateSt = string.Empty;
try
{
// first search against customers
var connection = new SqlConnection(System.Configuration.ConfigurationManager.ConnectionStrings["BAXISQL"].ConnectionString);
connection.Open();
var sqlCommand = connection.CreateCommand();
sqlCommand.CommandText = "SELECT dbo.WORKS_GetTrainingDate_fn(@URN, @Past, @Future)";
sqlCommand.Parameters.AddWithValue("@URN", urn);
sqlCommand.Parameters.AddWithValue("@Past", pastdays);
sqlCommand.Parameters.AddWithValue("@Future", futuredays);
string date = sqlCommand.ExecuteScalar().ToString();
connection.Close();
if (!string.IsNullOrWhiteSpace(date))
{
string[] parts = date.ToString().Split('/');
dateSt = parts[2] + parts[1] + parts[0];
}
}
catch (Exception e)
{
dateSt = "Error: " + e.Message + "<br />Source: " + e.Source + "<br />Stacktrace: " + e.StackTrace;
}
return dateSt;
}
#endregion
#region Private Methods
/// <summary>
/// Method to determine if the API key has been passed in succesfully
/// </summary>
/// <returns>true or false</returns>
private bool CheckAPIKey()
{
bool matchedKey = false;
IncomingWebRequestContext request = WebOperationContext.Current.IncomingRequest;
WebHeaderCollection headers = request.Headers;
System.Diagnostics.Debug.Write("\r\n-------------------------------------------------------");
System.Diagnostics.Debug.Write("\r\n" + request.Method + " " + request.UriTemplateMatch.RequestUri.AbsolutePath);
foreach (string headerName in headers.AllKeys)
{
System.Diagnostics.Debug.Write("\r\n" + headerName + ": " + headers[headerName]);
if (headerName.Equals("BAXI_SMS_KEY"))
{
if (baxiSMSKey.ToString().ToUpper().Equals(headers[headerName]))
{
matchedKey = true;
}
}
}
System.Diagnostics.Debug.Write("\r\n-------------------------------------------------------");
return matchedKey;
}
#endregion
}
}
当我尝试使用 Fiddler 和浏览器访问服务方法时,会出现这些 404 消息。在允许正在构建 Web 门户的第 3 方作为 Web 服务的客户端访问之前,我想证明这些方法工作正常。
如有任何意见或建议,我们将不胜感激。
提前致谢伊恩
最佳答案
在与一些同事进行搜索和讨论后,我找到了解决方案。我怀疑我的 web.config 文件中缺少一些部分。
我没有为 http 和 https 添加端点声明。
<services>
<service name="WorksWebService.WorksWebService">
<endpoint address="" behaviorConfiguration="restful" binding="webHttpBinding" bindingConfiguration="HttpBinding"
contract="WorksWebService.IWorksWebService" />
<endpoint address="" behaviorConfiguration="restful" binding="webHttpBinding" bindingConfiguration="HttpsBinding"
contract="WorksWebService.IWorksWebService" />
</service>
</services>
我还错过了定义安全性和所需凭证类型所需的相关绑定(bind)部分。
<bindings>
<webHttpBinding>
<binding name="HttpBinding">
<security mode="None">
<transport clientCredentialType="None"/>
</security>
</binding>
<binding name="HttpsBinding">
<security mode="Transport">
<transport clientCredentialType="None"/>
</security>
</binding>
</webHttpBinding>
</bindings>
现在我的 web.config 文件看起来像这样:
<?xml version="1.0"?>
<configuration>
<appSettings>
<add key="aspnet:UseTaskFriendlySynchronizationContext" value="true" />
</appSettings>
<system.web>
<compilation debug="true" targetFramework="4.5" />
<httpRuntime targetFramework="4.5"/>
</system.web>
<connectionStrings>
<add name="BAXISQL" connectionString="Database=SomeDatabase;Server=SomeServer;User ID=User;Password=Password" providerName="System.Data.SqlClient" />
</connectionStrings>
<system.serviceModel>
<services>
<service name="WorksWebService.WorksWebService">
<endpoint address="" behaviorConfiguration="restful" binding="webHttpBinding" bindingConfiguration="HttpBinding"
contract="WorksWebService.IWorksWebService" />
<endpoint address="" behaviorConfiguration="restful" binding="webHttpBinding" bindingConfiguration="HttpsBinding"
contract="WorksWebService.IWorksWebService" />
</service>
</services>
<behaviors>
<serviceBehaviors>
<behavior>
<!-- To avoid disclosing metadata information, set the values below to false before deployment -->
<serviceMetadata httpGetEnabled="true" httpsGetEnabled="true"/>
<!-- To receive exception details in faults for debugging purposes, set the value below to true. Set to false before deployment to avoid disclosing exception information -->
<serviceDebug includeExceptionDetailInFaults="true"/>
</behavior>
</serviceBehaviors>
<endpointBehaviors>
<behavior name="restful">
<webHttp/>
</behavior>
</endpointBehaviors>
</behaviors>
<protocolMapping>
<add binding="basicHttpsBinding" scheme="https" />
</protocolMapping>
<bindings>
<webHttpBinding>
<binding name="HttpBinding">
<security mode="None">
<transport clientCredentialType="None"/>
</security>
</binding>
<binding name="HttpsBinding">
<security mode="Transport">
<transport clientCredentialType="None"/>
</security>
</binding>
</webHttpBinding>
</bindings>
<serviceHostingEnvironment aspNetCompatibilityEnabled="true" multipleSiteBindingsEnabled="true" />
</system.serviceModel>
<system.webServer>
<modules runAllManagedModulesForAllRequests="true"/>
<!--
To browse web app root directory during debugging, set the value below to true.
Set to false before deployment to avoid disclosing web app folder information.
-->
<directoryBrowse enabled="true"/>
</system.webServer>
<startup>
<supportedRuntime version="4.0" sku=".NETFramework,Version=v4.0"/>
</startup>
</configuration>
我希望这对遇到类似问题的其他人有所帮助。
问候,
漫画程序员
关于c# - WCF Restful Web 服务端点公开但方法都返回 http 404 未找到 c#,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/31876575/
我有一个几乎可以构建的Maven / Grails应用,但在web.xml上找不到[my-app]\webapp\WEB-INF\web.xml。但是目录结构像往常一样包含web-app文件夹,而不是
正如我在标题中提到的:我想知道 web-service 和 web-socket 之间的区别?我们什么时候使用每一个? 谢谢! 最佳答案 一个web service是一个响应客户端 SOAP/REST
让我们看一个示例场景: 客户端打开一个网站并找到他从文本框中输入的两个数字的总和。然后单击“添加”按钮。两个参数通过 HTTP GET 发送到服务器,在服务器上写入 PHP 代码以添加数字,结果为回声
我知道这是一个老问题,肯定已经被回答了数百次,但我还无法找到令人满意的答案。 我正在创建一个应用程序,其他应用程序(移动/网络)将使用该应用程序来获取数据。现在我有两个选择: 将我的应用程序创建为简单
通过 Web 作业部署新功能有 3 种方法: 创建一个新的 Web 应用,并部署一个包含该函数的 Web 作业。 向现有 Web 作业添加一项新函数(这样您现在在一个 Web 作业中就拥有了多个函数)
我收到来自网络场景的通知,上面写着“问题”和“确定”。我想在问题发生时包含网络响应的内容。我不担心标题值,只担心网页的内容. 这是我可以在通知设置中引用的变量吗? 最佳答案 不幸的是 zabbix 不
就目前而言,这个问题不适合我们的问答形式。我们希望答案得到事实、引用或专业知识的支持,但这个问题可能会引起辩论、争论、投票或扩展讨论。如果您觉得这个问题可以改进并可能重新打开,visit the he
嗨,这是一个理论问题,但我真的无法弄清楚 Web 应用程序、基于 Web 的应用程序和基于云的应用程序之间的区别。这个你能帮我吗。 最佳答案 @Matt 是对的 - 这真的无关紧要,但是,为了清楚起见
我正在尝试使用多个 Web 服务,这些服务在它们的 wsdl 中重新定义了一些相同的公共(public)类。我目前在网站中引用了它们,但我想转换为 Web 应用程序。 由于一些相同的类是从多个 Web
一个。我必须考虑哪些事项?b.当前应用程序正在执行多个存储过程。如果我创建等效的方法来执行这些过程,会有什么风险或挑战。 最佳答案 在架构上,将网络应用程序转换为网络服务时必须考虑的一件事是,对方法和
关闭。这个问题不满足Stack Overflow guidelines .它目前不接受答案。 想改善这个问题吗?更新问题,使其成为 on-topic对于堆栈溢出。 5年前关闭。 Improve thi
网络 API 和网络服务之间有什么区别吗?或者它们是同一个吗? 最佳答案 网络服务通常提供 WSDL您可以从中自动创建客户端 stub 。 Web 服务基于 SOAP protocol 。ASP.NE
我已经获得了我需要的所有资源。我将 Web 服务放入应用程序服务环境中,然后将 NSG 连接到应用程序服务环境使用的子网。然后,我允许 VNET 内的应用程序与 Web 服务进行通信,但它无法正常工作
我已经获得了我需要的所有资源。我将 Web 服务放入应用程序服务环境中,然后将 NSG 连接到应用程序服务环境使用的子网。然后,我允许 VNET 内的应用程序与 Web 服务进行通信,但它无法正常工作
我正在使用 stub 将我的网络服务相关测试与实际网络服务隔离开来。 你/我应该如何合并测试以确保我制作的响应与实际的网络服务匹配(我无法控制它)? 我不想知道怎么做,而是何时何地? 我应该为测试数据
我在互联网上搜索了很多,但我仍然没有得到网络服务和网络 API 之间的明显区别?我在某处读到所有 Web 服务都是 API,但所有 API 都不是 Web 服务。如何? 我所知道的是两者都允许利用其他
假设我已经完成了使用 JavaEE 制作的 Web 应用程序。这个 Web 应用程序包含登录系统,但最后它是非常基本的 Web 应用程序。我使用的是 GlassFish 3.1.2.2。 我想知道一旦
我希望设计者能够打开与我相同的解决方案文件。这可以通过 Expressions Web 实现吗? 最佳答案 简短的回答是“不”;但这是一个非常常见的请求,我知道很多人都希望下一个版本(无论何时)对此有
我正在尝试在 CF10 中创建一个 Web 服务对象。我已验证它在 SoapUI 中按预期工作。但是,当我在 CF 中运行它时,我得到一个错误,它无法找到在 WSDL 的导入语句中导入的 XSD。这是
我的要求是开发一个 Web 服务,充当外部 Web 服务和客户端之间的中间人。 我知道,我可以为我的服务设计一个wsdl,然后将外部wsdl映射到代码中我的wsdl。我的问题是有一个开源 api/工具
我是一名优秀的程序员,十分优秀!