The NetworkIdentity component is a Unity component that is at the heart of the new networking system. It can be added to objects from the AddComponents->Network->NetworkIdentity menu item. This component controls an object’s network identity, and it makes the networking system aware of it. This shows what the NetworkIdentity component looks like on an object:
With the server authoritative system of the Unity Network System, networked objects with NetworkIdentities must be “spawned” by the server using NetworkServer.Spawn(). This causes them to be assigned a NetworkInstanceId and be created on clients that are connected to the server.
Scene objects are treated a bit differently than dynamically instantiated objects. These objects are all present in the scene on both client and server. However, when building the game all the scene objects with network identities are disabled. When the client connects to the server the server tells the client which scene objects should be enabled and what their most up to date state information is through spawn messages. This ensures the client will not contain objects placed at now incorrect locations when he starts playing, or even objects which will be deleted immediately on connection because some event removed them before the client connected. The “serverOnly” checkbox will ensure this a particular object will not be spawned or enabled on clients.
This component contains tracking information like what scene ID, network ID and asset ID the object has been assigned. The scene ID is valid in all scene objects with a NetworkIdentity component. The network ID is the ID of this particular object instance, there might be multiple objects instantiated of a particular object type and the network ID is used to identity which object, for example, a network update should be applied to. The asset ID refers to what source asset the object was instantiated from. This is used internally when an particular object prefab is spawned over the network. This information is exposed in the preview panel at the bottom of the inspector:
At runtime there is more information to display here (a disabled NetworkBehaviour is displayed non-bold):
Property: | Function: | |
---|---|---|
netId | A unique identifier for this network session, assigned when spawned. | |
sceneId | A unique identifier for networked objects in a scene. This is only populated in play-mode. | |
isClient | True if this object is running on a client. | |
isServer | True if this object is running on the server, and has been spawned. | |
hasAuthority | True if this object is the authoritative version of the object. So either on a the server, or on the client with localPlayerAuthority. | |
localPlayerAuthority | True if this object is controlled by the client that owns it - the local player object on that client has authority over it. This is used by other components such as NetworkTransform. | |
serverOnly | A flag to make this object not be spawned on clients. | |
assetId | This identifies the prefab associated with this object (for spawning). | |
playerControllerId | The identifier of the controller associated with this object. Only valid for player objects. | |
observers | The list of client NetworkConnections that are able to see this object. This is read-only. |
When you visit any website, it may store or retrieve information on your browser, mostly in the form of cookies. This information might be about you, your preferences or your device and is mostly used to make the site work as you expect it to. The information does not usually directly identify you, but it can give you a more personalized web experience. Because we respect your right to privacy, you can choose not to allow some types of cookies. Click on the different category headings to find out more and change our default settings. However, blocking some types of cookies may impact your experience of the site and the services we are able to offer.
More information
These cookies enable the website to provide enhanced functionality and personalisation. They may be set by us or by third party providers whose services we have added to our pages. If you do not allow these cookies then some or all of these services may not function properly.
These cookies allow us to count visits and traffic sources so we can measure and improve the performance of our site. They help us to know which pages are the most and least popular and see how visitors move around the site. All information these cookies collect is aggregated and therefore anonymous. If you do not allow these cookies we will not know when you have visited our site, and will not be able to monitor its performance.
These cookies may be set through our site by our advertising partners. They may be used by those companies to build a profile of your interests and show you relevant adverts on other sites. They do not store directly personal information, but are based on uniquely identifying your browser and internet device. If you do not allow these cookies, you will experience less targeted advertising. Some 3rd party video providers do not allow video views without targeting cookies. If you are experiencing difficulty viewing a video, you will need to set your cookie preferences for targeting to yes if you wish to view videos from these providers. Unity does not control this.
These cookies are necessary for the website to function and cannot be switched off in our systems. They are usually only set in response to actions made by you which amount to a request for services, such as setting your privacy preferences, logging in or filling in forms. You can set your browser to block or alert you about these cookies, but some parts of the site will not then work. These cookies do not store any personally identifiable information.