ПОСТАВКА DateTime из Android в службу WCF RESTful JSON - PullRequest
4 голосов
/ 02 июля 2010

Я пытаюсь отправить DateTime в качестве параметра в метод, предоставляемый через службу WCF RESTful с кодировкой JSON. Запрос выглядит так:

POST http://IP:PORT/LogService/json/GetLogEntriesByModule HTTP/1.1
Content-Length: 100
Content-Type: application/json
Host: IP:PORT
Connection: Keep-Alive
User-Agent: Apache-HttpClient/UNAVAILABLE (java 1.4)
Expect: 100-Continue

{"maxentries":10,"upperdate":"1280703601462","lowerdate":"1277938801462","module":"Windows Service"}

Я пробовал несколько форматов для DateTime:

  • 2010-07-01T10:54:00 (который отправляется приложением WCFTestClient через NET.TCP и получает результаты
  • \/Date(12345678+0100)\/
  • 01.07.2010 10:54:00

Определение метода:

LogEntry[] GetLogEntriesByModule(
    string module,
    DateTime lowerDate,
    DateTime upperDate,
    int maxEntries,
    out bool maxEntriesReached
)

Я всегда получаю следующий ответ:

HTTP/1.1 200 OK
Content-Length: 60
Content-Type: application/json; charset=utf-8
Server: Microsoft-HTTPAPI/2.0
Date: Fri, 02 Jul 2010 09:07:04 GMT

{"GetLogEntriesByModuleResult":[],"maxEntriesReached":false}

Кажется, DateTime не правильно проанализирован, потому что в журнале есть несколько записей для этого времени.

Кто-нибудь знает, как это сделать?

Обновление : проблема была на стороне сервера и была решена.

Ответы [ 4 ]

7 голосов
/ 01 марта 2011

В правильном формате для публикации дат в службе WCF используется: /Date(53244000000)/, где число в скобках - это количество миллисекунд с полуночи UTC 1970 года.

Date dt = new Date();
long date = Date.UTC(dt.getYear(), dt.getMonth(), dt.getDay(), dt.getHours(),dt.getMinutes(), dt.getSeconds());
String senddate = "/date("+date+")/";

А затем используйте его, как показано ниже

inputparam.put("DateTime", datetime);
2 голосов
/ 26 октября 2010

На всякий случай, если кому-то это поможет:

Согласно Microsoft, WCF использует QueryStringConverter для анализа URL.Таким образом, используя этот код (небольшая модификация примера msdn):

QueryStringConverter converter = new QueryStringConverter();
if (converter.CanConvert(typeof(DateTime)))
{
    string strValue = converter.ConvertValueToString(DateTime.UtcNow, typeof(DateTime));
    Console.WriteLine("the value = {0}", strValue);
}

мы получаем правильный формат для параметров REST DateTime: 2010-01-01T01: 01: 01Z

Я сделалпрочитайте, что вы пробовали этот формат, но просто хотели подтвердить, что это действительно так, как он должен работать.Я думал об ответе, так как этот вопрос возник первым, когда я искал это.

Это работало для меня, используя .NET 4.0

0 голосов
/ 17 апреля 2016

Это код, который я использую для отправки из Android Java в .NET WebApp.Создайте объект JSON с датой в XML-схеме W3C:

Calendar myCalendarObj = Calendar.getInstance(); // Snap a moment in time

JSONObject jObj = new JSONObject(); // Create a JSON object (org.json.JSONObject)

SimpleDateFormat jsonDateFormat = new SimpleDateFormat("yyyy-MM-dd'T'HH:mm:ssZ"); // from java.text.SimpleDateFormat
String senddate = jsonDateFormat.format(myCalendarObj.getTime());
jObj.put("a_date_field", senddate);
0 голосов
/ 20 июля 2013

Я должен обновить ответ на этот вопрос, мне нужно было сделать то же самое, и я использовал принятый ответ, но полученная Дата была неправильной, она давала мне дату недели раньше (Не знаю почему). Я не знаю много о типе даты Java, но я знаю, что некоторые из их методов устарели.

Говорят, что я думаю, что это самый последний правильный ответ для этой ситуации. Надежда помогает кому-то еще

import java.util.Date;
import java.util.GregorianCalendar;
import java.util.TimeZone;

.....

    final Calendar cal = GregorianCalendar.getInstance(TimeZone.getTimeZone("GMT"));        
    cal.setTime(value); // Where Value is a Date
    final long date = cal.getTime().getTime();
    final String senddate = "/Date("+date+")/";

Обратите внимание на использование Date с заглавными буквами "D" , это также необходимо, потому что это вызывает проблемы с WCF (по крайней мере, в моем случае, застрял много только для строчной буквы D)

Я использую его для использования RESTful WCF с библиотекой Джексона для JSON.

Чтобы добавить полный ответ, его можно использовать таким образом для даты, которую вы хотите сериализовать с Джексоном.

import java.io.IOException;
import java.util.Calendar;
import java.util.Date;
import java.util.GregorianCalendar;
import java.util.TimeZone;

import org.codehaus.jackson.JsonGenerationException;
import org.codehaus.jackson.JsonGenerator;
import org.codehaus.jackson.annotate.JsonCreator;
import org.codehaus.jackson.map.SerializerProvider;
import org.codehaus.jackson.map.ser.std.SerializerBase;

/**
 * @author HECTOR
 *
 */
public class SerializeRESTDate extends SerializerBase<Date> {

    public SerializeRESTDate() {
        // TODO Auto-generated constructor stub
        this(Date.class);
    }

    @JsonCreator
    protected SerializeRESTDate(Class<Date> t) {
        super(t);
        // TODO Auto-generated constructor stub
    }



    @Override
    public void serialize(Date value, JsonGenerator jgen,
            SerializerProvider provider) throws IOException,
            JsonGenerationException {


        final Calendar cal = GregorianCalendar.getInstance(TimeZone.getTimeZone("GMT"));            
        cal.setTime(value);
        final long date = cal.getTime().getTime();
        final String senddate = "/Date("+date+")/";
        jgen.writeString(senddate);

    }



}

И используйте это вот так в определении своего класса

@JsonSerialize(using = SerializeRESTDate.class)
    @JsonProperty("InspectionDate")
    /**
     * @return the _InspectionDate
     */
    public Date get_InspectionDate() {
        return _InspectionDate;
    }
...