j2me的最新版增加了对短信的支持,以后将陆续将javax.wireless.messaging下的文档 
按我的理解翻译过来,由于水平有限,错误再所难免,望大家指正。 
我的E-mail:[email protected] 
javax.wireless.messaging     Interface MessageConnection 
  接口MessageConnection为发送和接收短信定义了一些基本的机制。如:接受和发送短信的发法,建立一个新短信的工厂方法(factory method),计算底层协议发送信息时需要将其分成的段数。     一个MessageConnection可由Connector.open()得到,并且程序应当用close()关闭打开的连接。如果MessageConnection的任何声明抛出IOException的方法在它被关闭后被调用,则抛出IOException. 
  消息可由一个连接发送。一个连接可别定义为服务器(server)模式或客户端(client)模式。 
  在客户端模式下,连接只可以发送信息。客户端模式的连接可在调用Connector.open()时传入目的地址得到。这个方法将返回一个MessageConnection对象。 
  在服务器模式下,一个连接既可以发送也可以接受信息。服务器模式的连接可在调用Connector.open()时传入一个此连接的标识(与协议相关,比如:端口号)。若所指定的标识已被别的系统程序或Java程序占用,则Connector.open()将抛出IOException。Java程序可以用任何未被占用的end point标识打开MessageConnection,但是某些安全协议将有可能不允许它在那个end point上发送或接受信息。 
  这个接口并不假设任何协议相关的细节,所以适用于所有的无线消息协议。 
  一个程序可以同时打开不止一个MessageConnection,并且这些连接即可以是服务器模式,也可以是客户端模式。      程序可以建立一个实现了MessageListener接口的实例,并将它通setMessageListener( MessageListener l)注册给MessageConnection,以使MessageConnection在有信息到来是获得通报。这样就不必为了等待接收信息而使一个线程挂起了。 
—————————————————————————————————————   Field Detail 
  TEXT_MESSAGE   public static final java.lang.String TEXT_MESSAGE          表示文本信息的常量(值为"text")。如果这个常量被用做newMessage()的参数,则将返回一个实现了TextMessage接口的实例。 
  BINARY_MESSAGE   public static final java.lang.String BINARY_MESSAGE 
     表示二进制信息的常量(值为"binary")。如果这个常量被用做newMessage()的参数,则将返回一个实现了BinaryMessage接口的实例。 
————————————————————————————     Method Detail 
  newMessage   public Message newMessage(java.lang.String type) 
    依指定参数创建一个message的实例。当TEXT_MESSAGE被传入将返回一个实现了TextMessage接口的实例。当BINARY_MESSAGE被传入将返回一个实现了BinaryMessage接口的实例。实现者也可以定义其他的常量,及相应的Message的子接口。被当做参数传入的type是大小写敏感的,它将由String.equals()比较,所以只需要传入参数的值与所定义的常量的值相等既可。 
   当此方法由处于客户端模式的MessageConnection调用,则新建立的的Message对象将含有此连接的目的地址。 
   当此方法由处于服务器模式的MessageConnection调用,则新建立的的Message对象将不含有目的地址。你必须在发送消息前设定目的地址。 
   如果连接关闭了,此方法返回一个Message实例。 
Parameters:   type:建立什么样的Message.在本接口中定义了基本的消息类型。 Returns:   依所传入的参数建立的Message实例。 Throws:   java.lang.IllegalArgumentException:当参数不TEXT_MESSAGE,BINARY_MESSAGE,或其它实现者依其特殊的协议定义的常量时将抛出。      ————————————————————————————————————— 
newMessage public Message newMessage(java.lang.String type,                          java.lang.String address)     依指定参数创建一个以address为目的地址的message实例。type的意义同上。 
  如果连接关闭了,此方法返回一个Message实例。 
Parameters:   type:建立什么样的Message.在本接口中定义了基本的消息类型。   address:目的地址。 Returns:   依所传入的参数建立的Message实例。 Throws:   java.lang.IllegalArgumentException:当参数不TEXT_MESSAGE,BINARY_MESSAGE,或其它实现者依其特殊的协议定义的常量时将抛出。 
————————————————————————————————————— send public void send(Message msg)             throws java.io.IOException             java.io.InterruptedIOException 
  发送信息。      Paramenters:     msg:被发送的的信息。   Throws:     java.io.IOException: 当信息不能被送出,网络故障,或连接以关闭是抛出。     java.lang.IllegalArgumentException: 当信息不完整,包含非法信息,或当信息的长度超过了协议所要求的最大长度是抛出。一个特殊信息包含非法信息的例子是,MessageConncetion试图发送它不支持类型的信息。所以信息应总是用创建它的MessageConncetion发送。     java.io.InterruptedIOException:如果timeout在试图发送信息时发生,或在调用此方法时连接已关闭。     java.lang.NullPointerException:如果msg是null。     java.lang.SecurityException:如果程序没有发送信息的权限。 
————————————————————————————————————— receive public Message receive()                throws java.io.IOException                java.io.InterruptedIOException 
  接收信息。 
  如果没有信息,此方法挂起直到有信息到来,或MessageConnection被关闭。 
Returns:   一个代表接受到的信息的Message对象。 Throws:   java.io.IOException:当如下事件发生时抛出:        1。在接受信息是发生错误。        2。在连接关闭是调用此方法。        3。在客户端模式下调用此方法。   java.io.InterruptedIOException:在此方法执行时关闭连接时抛出。   java.lang.SecurityException:如果程序没有在指定端口接收信息的权限。 
————————————————————————————————————— 
setMessageListener public void setMessageListener(MessageListener l)                       throws java.io.IOException 
  注册MessageListener到这个MessageConnection使得当消息到来时能得到通知。 
  如果在调用此方法前消息队列非空,则新注册的listener将会被立即被通知到(每条消息通知一次)。      在任意时刻只能有唯一一个listener注册到MessageConnection上,新设定的listener将会自动取代老的listener。以null为此方法的参数将注销前的listener。 
Parameters:   1:被注册的MessageListener.若值为null则将注销当前的listener,从而接收不到任何通知。 Throws:   java.lang.SecurityException:如果程序没有在指定端口接收信息的权限。   java.lang.IOException:如果此连接以关闭,或试图在客户端模式下调用此方法。 
————————————————————————————————————— 
numberOfSegments public int numberOfSegments(Message msg) 
  返回底层协议发送信息时需要将其分成的段数。此方法并不发鹅送信息,只是计算需要的协议段。 
  此方法将计算由相应协议的方式分割信息所产生的段数,它并不关心具体协议实现时所规定的段数的上限。那些限制是协议相关的,将在实现者的文挡中指出。 
  当连接以被关闭是,此方法将返回计算所得的段数。 
Paramenters:   msg:被用来计算的信息。 Returns:   发送信息所需的协议段。如果上0则说明此信息不能用现在的底层协议发送。
   
 
  |