Code-based experience surfaces code-based-surface
What is a surface? surface-definition
A code-based experience surface is any entity designed for user or system interaction, uniquely identified by an URI. The surface is specified in the application implementation and must match the surface referenced in your code-based experience channel configuration.
A surface can be seen as a container at any level of hierarchy with an entity (touchpoint) that exists.
- 
                  It can be a web page, a mobile app, a desktop app, a specific content location within a larger entity (for example a div), or a non-standard display pattern (for example, a kiosk or a desktop app banner).
- 
                  It can also extend to specific pieces of content containers for non-display or abstracted-display purposes (for example, JSON blobs delivered to services). 
- 
                  It can also be a wildcard surface that matches a variety of client-surface definitions (for example, a hero image location on every page of your website could translate in a surface URI like: web://mydomain.com/*#hero_image). 
Surface identifier surface-uri
A surface URI serves as a precise identifier directing to distinct user interface elements or components within an application. Basically, a surface URI is composed of multiple sections:
- Type: web, mobileapp, atm, kiosk, tvcd, service, etc.
- Property: page URL or app bundle
- Container: location on the page/app activity
The tables below list some surface URI definition examples for various devices.
Web and mobile
web://domain.com/path/page.html#elementmobileapp://com.vendor.bundle/activity#elementmobileapp://com.vendor.bundle/#elementOther device types
desktop://com.vendor.bundle/#elementtvcd://com.vendor.bundle/#elementservice://servicename/#elementkiosk://location/screen#elementatm://location/screen#elementWildcard surfaces
wildcard:web://domain.com/*#elementwildcard:web://*domain.com/*#elementURI composition uri-composition
In Journey Optimizer, the code-based experience channel supports two types of customer implementations:
- Based on the 51黑料不打烊 Experience Platform Web SDK for your websites, or on the for you mobile apps;
- Server-side or hybrid using AEP Edge Network Server APIs.
Using code-based experiences, you can modify content on granular locations which are uniquely identified by Journey Optimizer using surface URIs.
These surface URIs are composed and handled depending on the implementation method:
- 
                  Web/Mobile SDK: Your web/mobile developer needs to define these granular locations as simple strings, because the Web/Mobile SDK is capable of automatically compose the surface URI based on the current URL/app ID and the location string. 
- 
                  Edge Network APIs: The app/page developer must define full surface URIs that include the full path and location where the content will be consumed, because the full URIs are required in this type of implementation. 
This is why, when creating a code-based experience channel configuration, you have two ways to specify the surface according to the selected platform:
- 
                  For Web, iOS and Android platforms, you need to the enter the URL/app ID and a location or path to compose the surface. Learn more about configuring code-based experiences for web and mobile platforms 
- 
                  If the platform is Other, you need to enter the full surface URI, like in the examples above. Learn more about configuring code-based experiences for other platforms