You are here:
ActiveXperts.com > SMS and MMS Toolkit > How to Use the SMS and MMS Toolkit > SMPP Provider > ASP.NET (C#)
Quicklinks
The SMS and MMS Toolkit is a software development kit (SDK) to enhance an application or script with SMS, MMS and Pager functionality. SMS messages can be sent using a GSM/GPRS modem, an SMPP provider, an HTTP compliant SMS provider or using a standard dialup or fixed-line SMS modem. MMS messages can be sent via a GSM/GPRS modem (MM1), an SMTP server (MM4) or an XML/SOAP compliant provider (MM7).
SMS features:
MMS features:
Pager features:
This document describes how the SMS and MMS Toolkit can be integrated into into ASP .NET (C#) projects.
You must install and configre Internet Information Services (IIS) before using the SMS and MMS Toolkit with ASP .NET
If you don't have IIS installed, use the following steps:
Make sure that ASP .NET is allowed on the web server:
(Click on the picture to enlarge)
Download the the SMS and MMS Toolkit from the ActiveXperts Download Site and start the installation. The installation guides you through the installation process.
Launch Microsoft Visual Studio (for instance 'Microsoft Visual Studio 2005') from the Start menu. Choose 'New' from the 'File' menu and click on 'Web Site'. In the 'Web Site' dialog, select ASP .NET Web Site. Select a name for the application (for instance: 'DemoApp') and a name for the solution (for instance: 'DemoSolution'). Also, select the directory where you want to store the project (for instance: 'C:\MyProjects):
(Click on the picture to enlarge)
Now that a new project has been created, you must add a reference to the SMS and MMS Toolkit in the project to be able to use the the SMS and MMS Toolkit objects. To do so, choose 'Add Reference...' from the 'Project' menu. In the 'Add Reference' dialog that pops up, select the 'COM' tab and select the ActiveXperts SMS and MMS Toolkit Type Library' as shown in the following picture:
(Click on the picture to enlarge)
Click 'OK' to close the 'Add Reference' dialog.
On top of your code, type the following line to use the SMS and MMS Toolkit namespace:
using AXmsCtrl;
In your Main function, declare and create the following objects:
private SmsProtocolSmpp objSmppProtocol; private SmsMessage objSmsMessage; private SmsConstants objSmsConstants; SmsProtocolSmpp objSmppProtocol = new SmsProtocolSmpp(); SmsMessage objSmsMessage = new SmsMessage(); SmsConstants objSmsConstants = new SmsConstants();
You can now send and/or receive SMS messages.
The following code shows how to send a SMS message:
webform.aspx.cs
using System;
using System.Collections;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Web;
using System.Web.SessionState;
using System.Web.UI;
using System.Web.UI.WebControls;
using System.Web.UI.HtmlControls;
using AXmsCtrl;
namespace SendSms
{
/// <summary>
/// Summary description for WebForm1.
/// </summary>
public class WebForm1 : System.Web.UI.Page
{
protected System.Web.UI.HtmlControls.HtmlForm Form1;
protected System.Web.UI.HtmlControls.HtmlInputText TextRecipient;
protected System.Web.UI.HtmlControls.HtmlTextArea TextMessage;
protected System.Web.UI.HtmlControls.HtmlInputCheckBox CheckboxUnicode;
protected System.Web.UI.HtmlControls.HtmlInputText TextResult;
protected System.Web.UI.HtmlControls.HtmlInputText TextReference;
protected System.Web.UI.HtmlControls.HtmlInputButton Submit;
private SmsProtocolSmpp objSmppProtocol;
private SmsMessage objSmsMessage;
private SmsConstants objSmsConstants;
private void Page_Load(object sender, System.EventArgs e)
{
objSmppProtocol = new SmsProtocolSmpp ();
objSmsMessage = new SmsMessage ();
objSmsConstants = new SmsConstants ();
}
#region Web Form Designer generated code
override protected void OnInit(EventArgs e)
{
//
// CODEGEN: This call is required by the ASP.NET Web Form Designer.
//
InitializeComponent();
base.OnInit(e);
}
/// <summary>
/// Required method for Designer support - do not modify
/// the contents of this method with the code editor.
/// </summary>
private void InitializeComponent()
{
this.Submit.ServerClick += new System.EventHandler(this.Submit_ServerClick);
this.Load += new System.EventHandler(this.Page_Load);
}
#endregion
private void Submit_ServerClick(object sender, System.EventArgs e)
{
object obj;
string strReference;
objSmppProtocol.Server = "smpp.activexperts-labs.com";
objSmppProtocol.ServerPort = 2775;
objSmppProtocol.SystemID = "AX008";
objSmppProtocol.SystemPassword = "812056";
objSmppProtocol.SystemType = "SMPP";
objSmppProtocol.ServerTimeout = 10000;
objSmppProtocol.SystemMode = objSmsConstants.asSMPPMODE_TRANSMITTER;
objSmppProtocol.LogFile = "C:\\SmsLogAsp.txt";
objSmsMessage.Recipient = TextRecipient.Value;
objSmsMessage.Data = TextMessage.Value;
if (CheckboxUnicode.Checked == true)
{
objSmsMessage.Format = objSmsConstants.asMESSAGEFORMAT_UNICODE;
}
else
{
objSmsMessage.Format = objSmsConstants.asMESSAGEFORMAT_TEXT;
}
Submit.Disabled = true;
objSmppProtocol.Connect();
Submit.Disabled = false;
if (objSmppProtocol.LastError != 0)
{
TextResult.Value = "ERROR #" + objSmppProtocol.LastError + " (" + objSmppProtocol.GetErrorDescription(objSmppProtocol.LastError) + ")";
}
Submit.Disabled = true;
obj = objSmsMessage;
strReference = objSmppProtocol.Send( ref obj );
Submit.Disabled = false;
if (objSmppProtocol.LastError != 0)
{
TextResult.Value = "ERROR #" + objSmppProtocol.LastError + " (" + objSmppProtocol.GetErrorDescription(objSmppProtocol.LastError) + ")";
TextReference.Value = "";
}
else
{
TextResult.Value = "SUCCESS";
TextReference.Value = strReference;
}
objSmppProtocol.Disconnect();
}
}
}
webform.aspx
<%@ Page language="c#" Codebehind="WebForm1.aspx.cs" AutoEventWireup="false" Inherits="SendSms.WebForm1" %>
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN" >
<html>
<head>
<title>ActiveXperts SMS and MMS Toolkit ASP.NET Sample (C#)</title>
<meta name="GENERATOR" Content="Microsoft Visual Studio 7.0">
<meta name="CODE_LANGUAGE" Content="C#">
<meta name="vs_defaultClientScript" content="JavaScript">
<meta name="vs_targetSchema" content="http://schemas.microsoft.com/intellisense/ie5">
</head>
<body>
<font face="sans-serif" size="2">
<hr size="1" color="#707070">
<h2>ActiveXperts SMS and MMS Toolkit ASP.NET Sample (C#)</h2>
<h3>Send an SMS message to a recipient through an SMPP provider.</h3>
IMPORTANT: For more details about using SMS and MMS Toolkit with ASP.NET: <a href="http://www.activexperts.com/support/xmstoolkit/#aspnet" target="_blank">
SMS and MMS Toolkit ASP.NET FAQ</a>.
<hr size="1" color="#707070">
<br>
<form id="Form1" method="post" runat="server">
<table border="0" bgcolor="#f0f0f0">
<tr>
<td valign="top">Recipient:</td>
<td><input size="50" type="text" value="<enter recipient number>" id="TextRecipient" runat="server" NAME="TextRecipient"></td>
</tr>
<tr>
<td valign="top">Message:<br>(max. 160 chars)</td>
<td><textarea rows="3" cols="65" id="TextMessage" runat="server" NAME="TextMessage">Hello, world</textarea></td>
</tr>
<tr>
<td valign="top"> </td>
<td><input type="checkbox" id="CheckboxUnicode" runat="server" NAME="CheckboxUnicode">Send message as Unicode</td>
</tr>
<tr>
<td valign="top">Result: </td>
<td><input size="50" type="text" id="TextResult" runat="server" NAME="TextResult"></td>
</tr>
<tr>
<td valign="top">Message Reference: </td>
<td><input size="50" type="text" id="TextReference" runat="server" NAME="TextReference"></td>
</tr>
</table>
<br>
<hr size="1" color="#707070">
<br>
<input type="submit" value="Send Message" id="Submit" runat="server" NAME="Submit">
<br>
<br>
<hr size="1" color="#707070">
</form>
</font>
</body>
</html>
There are many working samples included with the product. You can also find them on the ActiveXperts FTP site: ftp.activexperts-labs.com/samples/mobile-messaging-component.
The project ships with a set of Microsoft Visual Studio .NET samples, including samples for Microsoft ASP .NET C#. The projects are created with Microsoft Visual Studio 2005.
Users with a later version of Microsoft Visual Studio can open such a project. The Visual Studio Conversion Wizard will guide you through the process of converting the project to the version used.