JavaScript – XML-Datum konvertieren
Wird per JavaScript ein Datumsfeld mit dem Webservice ermittelt, liefert das CRM das Datum in der UTC-Zeit mit der Zeitzonenverschiebung zurück, also z.B. ‚2010-12-05T00:00:00+01:00‘.
Um dieses Datum jetzt in ein deutsches Format 05.12.2010 als String umzuwandeln, kann folgender Code verwendet werden:
function DateTimeToStringConvert(source)
{
var source1 = source.split('T')[0];
var parts = source1.split('-');
var dat;
dat = parts[2];
dat = dat + '.' + parts[1];
dat = dat + '.' + parts[0];
return dat;
}
var stringdate = StringToDateTimeConvert(‚2010-12-05T00:00:00+02:00‘);
alert(stringdate);
Object Type Code ermitteln
Mit folgender Funktion kann dieser Wert dynamisch ermittelt werden.
function GetObjectTypeCodeForEntity(Entity)
{
var xml = "" +
"<?xml version=\"1.0\" encoding=\"utf-8\"?>" +
"<soap:Envelope xmlns:soap=\"http://schemas.xmlsoap.org/soap/envelope/\" xmlns:xsi=\"http://www.w3.org/2001/XMLSchema-instance\" xmlns:xsd=\"http://www.w3.org/2001/XMLSchema\">" +
GenerateAuthenticationHeader() +
" <soap:Body>" +
" <Execute xmlns=\"http://schemas.microsoft.com/crm/2007/WebServices\">" +
" <Request xsi:type=\"RetrieveEntityRequest\">" +
" <MetadataId>00000000-0000-0000-0000-000000000000</MetadataId>" +
" <EntityItems>EntityOnly</EntityItems>" +
" <LogicalName>" + Entity + "</LogicalName>" +
" <RetrieveAsIfPublished>true</RetrieveAsIfPublished>" +
" </Request>" +
" </Execute>" +
" </soap:Body>" +
"</soap:Envelope>" +
"";
var xmlHttpRequest = new ActiveXObject("Msxml2.XMLHTTP");
xmlHttpRequest.Open("POST", "/mscrmservices/2007/MetaDataService.asmx", false);
xmlHttpRequest.setRequestHeader("SOAPAction","http://schemas.microsoft.com/crm/2007/WebServices/Execute");
xmlHttpRequest.setRequestHeader("Content-Type", "text/xml; charset=utf-8");
xmlHttpRequest.setRequestHeader("Content-Length", xml.length);
xmlHttpRequest.send(xml);
var resultXml = xmlHttpRequest.responseXML.selectSingleNode("//ObjectTypeCode");
return resultXml.text;
}
alert("ObjectTypeCode: " + GetObjectTypeCodeForEntity("new_entity"));
Webservice in CRM 4.0 nutzen
Das folgende Beispiel zeigt einen sehr einfachen Weg, um dies zu erreichen.
// Prüfen, ob das LookUp Feld überhaupt Daten enthält
if (crmForm.all.new_lookupfield.DataValue != null)
{
// Die ID des Datensatzes zuweisen
var myId = crmForm.all.new_lookupfield.DataValue[0].id;
// Definieren der SOAP XML Message für den Zugriff auf den CRM Webservice
// Hier wird auch die Funktion GenerateAuthenticationHeader verwendet, die automatisch die korrekte Anmeldung ermittel
var xml = "" +
"<?xml version=\"1.0\" encoding=\"utf-8\"?>" +
"<soap:Envelope xmlns:soap=\"http://schemas.xmlsoap.org/soap/envelope/\" xmlns:xsi=\"http://www.w3.org/2001/XMLSchema-instance\" xmlns:xsd=\"http://www.w3.org/2001/XMLSchema\">" +
GenerateAuthenticationHeader() +
" <soap:Body>" +
" <RetrieveMultiple xmlns=\"http://schemas.microsoft.com/crm/2007/WebServices\">" +
" <query xmlns:q1=\"http://schemas.microsoft.com/crm/2006/Query\" xsi:type=\"q1:QueryExpression\">" +
" <q1:EntityName>contact</q1:EntityName>" +
" <q1:ColumnSet xsi:type=\"q1:ColumnSet\">" +
" <q1:Attributes>" +
" <q1:Attribute>new_number</q1:Attribute>" +
" </q1:Attributes>" +
" </q1:ColumnSet>" +
" <q1:Distinct>false</q1:Distinct>" +
" <q1:PageInfo>" +
" <q1:PageNumber>1</q1:PageNumber>" +
" <q1:Count>50</q1:Count>" +
" </q1:PageInfo>" +
" <q1:Criteria>" +
" <q1:FilterOperator>And</q1:FilterOperator>" +
" <q1:Conditions>" +
" <q1:Condition>" +
" <q1:AttributeName>contactid</q1:AttributeName>" +
" <q1:Operator>Equal</q1:Operator>" +
" <q1:Values>" +
" <q1:Value xmlns:q2=\"http://microsoft.com/wsdl/types/\" xsi:type=\"q2:guid\">" + myId + "</q1:Value>" +
" </q1:Values>" +
" </q1:Condition>" +
" </q1:Conditions>" +
" </q1:Criteria>" +
" </query>" +
" </RetrieveMultiple>" +
" </soap:Body>" +
"</soap:Envelope>" +
"";
// Eine Instance des XMLHTTP Objektes erzeugen
var xmlHttpRequest = new ActiveXObject("Msxml2.XMLHTTP");
xmlHttpRequest.Open("POST", "/mscrmservices/2007/CrmService.asmx", false);
xmlHttpRequest.setRequestHeader("SOAPAction", "http://schemas.microsoft.com/crm/2007/WebServices/RetrieveMultiple");
xmlHttpRequest.setRequestHeader("Content-Type", "text/xml; charset=utf-8");
xmlHttpRequest.setRequestHeader("Content-Length", xml.length);
xmlHttpRequest.send(xml);
if(xmlHttpRequest.status == 200)
{
var resultXml = xmlHttpRequest.responseXML;
var entityNodes = resultXml.selectNodes("//RetrieveMultipleResult/BusinessEntities/BusinessEntity");
for (var i = 0; i < entityNodes.length; i++)
{
var entityNode = entityNodes[i];
var new_numberNode = entityNode.selectSingleNode("q1:new_number");
var new_number = (new_numberNode == null) ? null : new_numberNode.text;
crmForm.all.<Feldname>.DataValue = new_number;
}
}
}