How to Send an RCS Message with Twilio and C# .NET
Time to read: 5 minutes
With the advent of Rich Communication Services (RCS), businesses are leveling up how they engage their customers. RCS brings a modern messaging experience that mirrors the interactive features of messaging apps that today’s consumers are accustomed to, while still delivering the reliability of SMS.
Apple devices also now support RCS as of the release of iOS 18. This has opened the door to new opportunities for integrating RCS.
In this tutorial, we’ll show you how to get started with RCS using Twilio and C# with .NET.
Comparing RCS to SMS and WhatsApp
SMS is simple and sticky, meeting end users where they’re at. RCS enhances SMS by tacking on advanced features similar to those of modern messaging apps like WhatsApp. This brings a rich and interactive messaging experience to the consumer, and they don’t need to download a new app to get it. With RCS, businesses can leverage multimedia, verified sender profiles, and comprehensive engagement tracking support.
To see RCS in comparison with other messaging channels, see our Guide to Rich Communication Services: What Developers Need to Know.
Implementing RCS with Twilio and C# with .NET
If you’re ready to start sending messages via RCS, then Twilio is the place to get started. We’ll walk you through how to create an RCS sender and a messaging service. Then, we’ll show you how to send your first RCS message using C#.
Prerequisites
To get started, you will need the following:
- A Twilio account (sign up here).
- A Twilio phone number for sending SMS, as a fallback to your RCS service.
- A device capable of receiving RCS messages.
- The .NET framework installed on your development machine.
Step 1: Create an RCS Sender
1. Log in to the Twilio Console.
2. Navigate to the Explore Products section and click RCS.
• If RCS isn’t visible, you may need to request access here.
data:image/s3,"s3://crabby-images/bc7aa/bc7aabda7ae90361a1c72b6423e4a4457aa696fd" alt="Screenshot of a web dashboard showing various communication services options with side navigation menu. Screenshot of a web dashboard showing various communication services options with side navigation menu."
data:image/s3,"s3://crabby-images/bc7aa/bc7aabda7ae90361a1c72b6423e4a4457aa696fd" alt=""
3. In the side panel, navigate to the Senders section.
4. Click Create new sender.
data:image/s3,"s3://crabby-images/80f23/80f235a745619d4b9d2e14ec7b311b64e4686a83" alt="Web interface for managing email senders with sidebar options and a button to create a new sender Web interface for managing email senders with sidebar options and a button to create a new sender"
data:image/s3,"s3://crabby-images/80f23/80f235a745619d4b9d2e14ec7b311b64e4686a83" alt=""
5. Provide a name (for example: “My First RCS Sender”). Click the continue button.
data:image/s3,"s3://crabby-images/5cb85/5cb8566d6a9abdd1b879af6c830453bef91234d1" alt="Dialog box for creating a new sender with display name and email, and instruction to add name and continue. Dialog box for creating a new sender with display name and email, and instruction to add name and continue."
data:image/s3,"s3://crabby-images/5cb85/5cb8566d6a9abdd1b879af6c830453bef91234d1" alt=""
Step 2: Add Profile Information
Next, you’ll add profile information for your RCS sender. Use the following:
- Sender display name: Choose a recognizable name for your sender. Usually, this is your brand name. For our example, we will use “My First RCS Sender”.
- Description: Describe your brand. This description will be displayed just under your display name at the top of your user’s RCS interactions.
- Border color: Keep in mind the minimum contrast ratio. For testing purposes, start with
#000000
to keep it simple. - Logo: Your brand logo should meet the following requirements:
• Dimensions: 224x224 pixels
• File size: Max 50 KB
• Image type: JPEG/JPG/PNG
• For testing, you can use this example image:https://corn-lobster-7338.twil.io/assets/twiliodevs-logo-rcs.png
- Banner: Your brand banner should meet the following requirements:
• Dimensions: 1440x448 pixels
• File size: Max 200KB
• Image type: JPEG/JPG/PNG
• For testing, you can use this example image:https://corn-lobster-7338.twil.io/assets/twiliodevs-banner-rcs.png
- Contact Details - Phone number: A phone number associated with your RCS sender is required. Optionally, you can also add an email address.
- Link to privacy policy and Link to terms of service: For testing purposes, you can enter links to arbitrary information here. When you begin building for production usage, make sure to create an RCS sender with real information about your business.
data:image/s3,"s3://crabby-images/d710d/d710de933fdad45db2113ae868dffc6e7c6237cf" alt="User filling out profile information and creating a Twilio sender profile on a computer screen. User filling out profile information and creating a Twilio sender profile on a computer screen."
data:image/s3,"s3://crabby-images/d710d/d710de933fdad45db2113ae868dffc6e7c6237cf" alt=""
Step 3: Test Your RCS Sender
- On the optional Test tab, click Add device to test this sender.
data:image/s3,"s3://crabby-images/a9a8e/a9a8ecf2046056aa70cfd5587f52a41a6130bc96" alt="Confirmation page to test sender and add phone as a test device, including a sample message demo. Confirmation page to test sender and add phone as a test device, including a sample message demo."
data:image/s3,"s3://crabby-images/a9a8e/a9a8ecf2046056aa70cfd5587f52a41a6130bc96" alt=""
- Enter the phone number of your RCS-capable device and click Invite.
- You should receive an opt-in message from Twilio’s RCS agent on your device.
- Confirm the opt-in on your device by selecting Make me a tester.
- Check the dialog box in the Twilio Console, and send a test message.
data:image/s3,"s3://crabby-images/99ac5/99ac5469ec84e02449d3eaa2166d88e5ced51a62" alt="Instructions on a phone and computer for confirming a test device and sending a first RCS message. Instructions on a phone and computer for confirming a test device and sending a first RCS message."
data:image/s3,"s3://crabby-images/99ac5/99ac5469ec84e02449d3eaa2166d88e5ced51a62" alt=""
- Celebrate—you’ve just sent your first RCS message!
data:image/s3,"s3://crabby-images/321ad/321ad91c158baa51fc5a5b33671cbb59ba086f0c" alt="Smartphone displaying an RCS message from a Twilio sender with a large hashtag symbol in the background. Smartphone displaying an RCS message from a Twilio sender with a large hashtag symbol in the background."
data:image/s3,"s3://crabby-images/321ad/321ad91c158baa51fc5a5b33671cbb59ba086f0c" alt=""
- Since this is just a test sender, click Save as draft and close.
data:image/s3,"s3://crabby-images/03e5d/03e5dacf1768406ec0e9f9807b966d621381b262" alt="Interface to create a sender in Twilio with phone number input and message preview on mobile screen. Interface to create a sender in Twilio with phone number input and message preview on mobile screen."
data:image/s3,"s3://crabby-images/03e5d/03e5dacf1768406ec0e9f9807b966d621381b262" alt=""
Step 4: Create a Messaging Service
- In the Console, navigate to Messaging > Services.
- Click Create Messaging Service.
data:image/s3,"s3://crabby-images/0386f/0386f8ea2a944d0bec2239ca11e550c9f774cef0" alt="Screenshot of messaging services dashboard featuring a search bar and a Create Messaging Service button. Screenshot of messaging services dashboard featuring a search bar and a Create Messaging Service button."
data:image/s3,"s3://crabby-images/0386f/0386f8ea2a944d0bec2239ca11e550c9f774cef0" alt=""
- Give the new service a name (for example: “My RCS Service”) and click Create Messaging Service.
data:image/s3,"s3://crabby-images/c3f68/c3f6803d6c06161d1993a8c627aec09b3c32480d" alt="Web interface showing steps and fields for setting up a messaging service on a platform. Web interface showing steps and fields for setting up a messaging service on a platform."
data:image/s3,"s3://crabby-images/c3f68/c3f6803d6c06161d1993a8c627aec09b3c32480d" alt=""
- Add your RCS sender.
- Click Add Sender, select RCS Sender.
data:image/s3,"s3://crabby-images/b616f/b616f875a4dbb738d36956b36bae33abb64168b2" alt="Popup for adding a sender with RCS sender type selected on a messaging platform. Popup for adding a sender with RCS sender type selected on a messaging platform."
data:image/s3,"s3://crabby-images/b616f/b616f875a4dbb738d36956b36bae33abb64168b2" alt=""
- Add the RCS sender you just created.
data:image/s3,"s3://crabby-images/21e6c/21e6cc1d1fdd05c255537239ca44c660f856a588" alt="Screenshot of a web interface for adding RCS senders with the option to select the RCS agent. Screenshot of a web interface for adding RCS senders with the option to select the RCS agent."
data:image/s3,"s3://crabby-images/21e6c/21e6cc1d1fdd05c255537239ca44c660f856a588" alt=""
- Add an SMS fallback sender by repeating the Add Sender process and selecting a phone number (or other SMS-capable sender). Then, click Step 3: Set up integration.
data:image/s3,"s3://crabby-images/62653/626534354f2e5afdc975ab8fe89757d8a3d58c8d" alt="Messaging Service Sender Pool Configuration Screen Messaging Service Sender Pool Configuration Screen"
data:image/s3,"s3://crabby-images/62653/626534354f2e5afdc975ab8fe89757d8a3d58c8d" alt=""
Step 5: (Optional) Set Up Webhook Integration
- Webhooks allow you to handle incoming messages in the same way as SMS or WhatsApp. Learn more in Twilio's docs about Incoming Message Webhooks.
- Use the Set Up Integration option to register a webhook. Feel free to reuse an existing one if available.
data:image/s3,"s3://crabby-images/fe8d2/fe8d207a452215fdb2d3aab04db94e4333d78267" alt="Screenshot of IBM Messaging Service integration setup with optional webhook configuration highlighted. Screenshot of IBM Messaging Service integration setup with optional webhook configuration highlighted."
data:image/s3,"s3://crabby-images/fe8d2/fe8d207a452215fdb2d3aab04db94e4333d78267" alt=""
Step 6: Send Your First RCS Message with C#
1. Finish the wizard flow by clicking the white Skip setup button.
data:image/s3,"s3://crabby-images/92b73/92b73016614f312754e33a78f16489bc9b28ece2" alt="Screenshot of Meta Messenger Send API settings page with Skip the rest of the wizard highlighted. Screenshot of Meta Messenger Send API settings page with Skip the rest of the wizard highlighted."
data:image/s3,"s3://crabby-images/92b73/92b73016614f312754e33a78f16489bc9b28ece2" alt=""
2. Copy the Messaging Service SID (like MGe1fdfb207e9aa5b44f398b1094d88a8b
) from the Console.
data:image/s3,"s3://crabby-images/8b587/8b58709c8c1ad29cf2c3a17e2363642a07da1a0e" alt="Twilio dashboard with steps to copy the messaging service SID under properties section in My SIP Services. Twilio dashboard with steps to copy the messaging service SID under properties section in My SIP Services."
data:image/s3,"s3://crabby-images/8b587/8b58709c8c1ad29cf2c3a17e2363642a07da1a0e" alt=""
3. Retrieve your Account SID and Auth Token from the Twilio Console.
4. Create a new project with the .NET CLI.
5. Create a file in your project folder called .env
. Add the credentials from the previous steps, so that your file looks like this:
6. Add the dependency packages you will use in your application code.
7. Edit the auto-generated Program.cs
file to look like this:
8. Build and run the application.
9. See the result on your RCS-enabled device.
data:image/s3,"s3://crabby-images/778a8/778a8757ce4ceaa5c6f29f3c86f52efff7f79fa2" alt="Phone screen displaying an RCS message received from a Twilio sender along with Twilio and RCS logos. Phone screen displaying an RCS message received from a Twilio sender along with Twilio and RCS logos."
data:image/s3,"s3://crabby-images/778a8/778a8757ce4ceaa5c6f29f3c86f52efff7f79fa2" alt=""
Explore Advanced RCS Features
You have successfully sent an RCS message using C# with .NET. Nice work!
When businesses use RCS to engage their customers, they get access to new avenues for engagement and interactivity. To continue leveling up your skills, check out some of the other things you can do in conjunction with RCS:
- Use the Content Template Builder to create rich message content which you can use across various channels, including SMS, WhatsApp, and RCS.
- Explore the Programmable Messaging Logs to see message statuses and troubleshoot any errors.
- Work with Twilio Verify to send OTP codes with RCS. Twilio Verify lets you deliver secure and engaging one-time passwords to your users.
Twilio is continuously enhancing its RCS capabilities. This includes new features like failover for undelivered messages and quick reply buttons. There’s more coming, so stay tuned for updates!
Modern businesses are using RCS to transform their customer engagement approach. With RCS, you get the reliability of SMS with the interactive features that end users expect from the messaging apps they know and love.
We can’t wait to see what you build!
Related Posts
Related Resources
Twilio Docs
From APIs to SDKs to sample apps
API reference documentation, SDKs, helper libraries, quickstarts, and tutorials for your language and platform.
Resource Center
The latest ebooks, industry reports, and webinars
Learn from customer engagement experts to improve your own communication.
Ahoy
Twilio's developer community hub
Best practices, code samples, and inspiration to build communications and digital engagement experiences.