web-dev-qa-db-fra.com

Comment renvoyer JSON depuis webservice

Matin,

Je dois renvoyer un message de mon service Web. Vous trouverez ci-dessous un exemple de mon code, et je retourne une chaîne. 

[web method]
public string CheckFeedSubmission()
    {
        string responseText = "";
        try
        {
            //Stuff goes here
            responseText = "It Worked!"
        }
        catch (Exception ex) { responseText = "Opps wehave an error! Exception message:" + ex.Message; }
        return responseText ;
    }

Je reçois actuellement la réponse suivante ...

<string xmlns="http://tempuri.org/"/>

J'aimerais idéalement retourner quelque chose comme

 {"success" : true, "message" : "***Message Here***"}

Je suis sûr que dès que j'en aurai l'idée, je pourrai renvoyer d'autres éléments si nécessaire. C'est juste cette base, j'ai besoin de travailler.

Toute aide est très appréciée, merci d'avance :)

UPDATE: Je viens de trouver ça ...

 return "{Message:'hello world'}"

Aurais-je besoin de quelque chose comme 

 responseText = "{"success" : true, "message" : \"There has been an error. Message: " + ex.Message + "\"}"
9
thatuxguy

Utilisation:

[WebMethod]
[ScriptMethod(ResponseFormat = ResponseFormat.Json)]//Specify return format.
public string CheckFeedSubmission()
    {
        string responseText = "";
        try
        {
            //Stuff goes here
            responseText = "It Worked!"
        }
        catch (Exception ex) { responseText = "Opps wehave an error! Exception message:" + ex.Message; }
        return responseText ;
    }

Le résultat renvoyé sera comme:

<string xmlns="http://tempuri.org/"/>
 {"success" : true, "message" : "***Message Here***"}
</string>
11
Ashwin Singh

Veuillez utiliser l'attribut pour votre méthode Web.

   [WebMethod]
    [ScriptMethod(ResponseFormat = ResponseFormat.Json)]

L'appelant aura défini son type de contenu sur application/json pour utiliser la méthode Web.

2
HatSoft

This ma solution pour le framework 4.5.2, Dans la classe FilterConfig, ajoutez le code suivant, Remarque: vous aurez besoin de la lib Newtonsoft.

 public class FilterConfig
{
    public static void RegisterGlobalFilters(GlobalFilterCollection filters)
    {
        GlobalConfiguration.Configuration.Formatters.JsonFormatter.SerializerSettings.ReferenceLoopHandling = Newtonsoft.Json.ReferenceLoopHandling.Serialize;
        GlobalConfiguration.Configuration.Formatters.Remove(GlobalConfiguration.Configuration.Formatters.XmlFormatter);
        GlobalConfiguration.Configuration.EnableCors();
        filters.Add(new HandleErrorAttribute());
    }
}
0
Leonardo Mora

Essaye celui-là :

[WebMethod] 
[ScriptMethod(ResponseFormat = ResponseFormat.Json)]//Specify return format. 
public bool addUser(UserModel um)
    {
        bool result = false;
        result = Conversion.intToBool(SplashAwardsDB.executeNonQuery(
            "INSERT INTO dbo.User ("
            + "userName, password, firstName, lastName, address, contactNo, birthDate, familyID, familyRole, x, y ) "
            + " VALUES ("
            + "'" + um.userName + "', "
            + "'" + um.password + "', "
            + "'" + um.firstName + "', "
            + "'" + um.lastName + "', "
            + "'" + um.address + "', "
            + "'" + um.contactNo + "', "
            + "'" + um.birthDate + "', "
            + "'" + um.familyID + "', "
            + "'" + um.familyRole + "', "
            + "'" + um.x + "', "
            + "'" + um.y + "')"
            ));
        return result;
    }
0
Ravin Singh

Pour supprimer les balises XML dans votre réponse de service, voir cette réponse sur StackOverflow: 

Le service Web ASP.NET encapsule ma réponse JSON avec des balises XML

0
kalenwatermeyer