Salesforce中通过SOAP API和Metadata API开发java的web server服务

本文介绍如何使用Java通过Salesforce的SOAP API进行数据查询。示例代码展示了如何配置连接、登录并查询定制对象MYSOBJECt__c的最新记录。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

Salesforce中通过SOAP API和Metadata API开发java的web server服务

参考

package wsc;


import com.sforce.soap.enterprise.Connector;
import com.sforce.soap.enterprise.DeleteResult;
import com.sforce.soap.enterprise.EnterpriseConnection;
import com.sforce.soap.enterprise.Error;
import com.sforce.soap.enterprise.QueryResult;
import com.sforce.soap.enterprise.SaveResult;
import com.sforce.soap.enterprise.sobject.SObject;
import com.sforce.soap.enterprise.sobject.MYSOBJECt__c;
import com.sforce.soap.metadata.MetadataConnection;
import com.sforce.soap.enterprise.LoginResult;


import com.sforce.ws.ConnectionException;
import com.sforce.ws.ConnectorConfig;


import java.io.FileWriter;
import java.nio.file.Path;
import java.nio.file.Paths;
import java.text.SimpleDateFormat;
import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.Map;

public class wsctest {
	static final String USERNAME = "userName";  
	static final String PASSWORD = "password";
	static EnterpriseConnection connection;
	
	
	public static void main(String[] args) {
	    ConnectorConfig config = new ConnectorConfig();
	
	    config.setUsername(USERNAME);
	    config.setPassword(PASSWORD);
	  
	    config.setAuthEndpoint("https://test.salesforce.com/services/Soap/c/40.0/") ;
		//config.setTraceMessage(true);
		config.setProxy("XXX", 0000);

		try {
		  connection = Connector.newConnection(config);
		
		  queryContacts();
		  System.out.println("Auth EndPoint: "+config.getAuthEndpoint());
		  System.out.println("Service EndPoint: "+config.getServiceEndpoint());
		  System.out.println("Username: "+config.getUsername());
		  System.out.println("SessionId: "+config.getSessionId());
		     
	    } catch (ConnectionException e1) {
	        e1.printStackTrace();
	    }
	    
	}
	  
	private static void queryContacts() {
		    
		System.out.println("Querying for the 5 newest Contacts...");
		Map<String,List<String>> idMap = new HashMap<String,List<String>>();
	
		try {
		   
		  // query for the 5 newest contacts      
		  QueryResult queryResults = connection.query("SELECT "
		  		+ "ID," 
		  		+ "NAME"  
		    + " FROM MYSOBJECt__c"  
		  	System.out.println("=====queryResults.getSize()======"+queryResults.getSize());
		  	List<MYSOBJECt__c> plaList = new ArrayList<MYSOBJECt__c>();
		  if (queryResults.getSize() > 0) {
		    for (int i=0;i<queryResults.getRecords().length;i++) {
		    	MYSOBJECt__c pla = (MYSOBJECt__c)queryResults.getRecords()[i];
		    	plaList.add(pla);
		    	pla.Name("test");

		    
		
		     String control =  pla.getName();

		      
		      if(idMap.get(control) == null){
		    	  List<String> ids = new ArrayList<String>();
		    	  ids.add(pla.getId());
		    	  idMap.put(control,ids);
		      }else{
		    	  idMap.get(control).add(pla.getId());
		      }
		    }
		    
		    for(String key :idMap.keySet()){
		    	System.out.println("======key======"+key);
	        }
	      }
		      
		} catch (Exception e) {
	      e.printStackTrace();
	    }    
	    
	  }
}

 

 

 

 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值