Important: UNet is a deprecated solution, and a new Multiplayer and NetworkingThe Unity system that enables multiplayer gaming across a computer network. More info See in Glossary Solution (Netcode for GameObjects) is under development. For more information and next steps see the information on the Unity Netcode for GameObjects website. |
The Network Identity component is at the heart of the Unity networking high-level API. It controls a GameObjectThe fundamental object in Unity scenes, which can represent characters, props, scenery, cameras, waypoints, and more. A GameObject’s functionality is defined by the Components attached to it. More info
See in Glossary’s unique identity on the network, and it uses that identity to make the networking system aware of the GameObject.
Property | Function |
---|---|
Server Only | Tick this checkbox to ensure that Unity only spawns the GameObject on the server, and not on clients. |
Local Player Authority | Tick this checkbox to give authoritative network control of this GameObject to the client that owns it. The player GameObject on that client has authority over it. Other components such as Network Transform use this to determine which client to treat as the source of authority. |
With the Unity’s server-authoritative networking system, the server must spawn networked GameObjects with network identities, using NetworkServer.Spawn. This automatically creates them on clients that are connected to the server, and assigns them a NetworkInstanceId.
You must put a Network Identity component on any PrefabsAn asset type that allows you to store a GameObject complete with components and properties. The prefab acts as a template from which you can create new object instances in the scene. More info
See in Glossary that spawn at runtime for the network system to use them.
You can also network GameObjects that are saved as part of your SceneA Scene contains the environments and menus of your game. Think of each unique Scene file as a unique level. In each Scene, you place your environments, obstacles, and decorations, essentially designing and building your game in pieces. More info
See in Glossary (for example, environmental props). Networking GameObjects makes them behave slightly differently, because you need to have them spawn across the network.
When building your game, Unity disables all Scene-based GameObjects with Network Identity components. When a client connects to the server, the server sends spawn messages to tell the client which Scene GameObjects to enable and what their most up-to-date state information is. This ensures the client’s game does not contain GameObjects at incorrect locations when they start playing, or that Unity does not spawn and immediately destroy GameObjects on connection (for example, if an event removed the GameObject before that client connected).
This component contains network tracking information, and displays that information in the preview pane. For example, the scene ID, network ID and asset ID the object has been assigned. This allows you to inspect the information which can be useful for investigation and debugging.
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 from a particular prefab, and the network ID is used to identity which object a network update should be applied to. The asset ID refers to which source asset the object was instantiated from. This is used internally when a particular GameObject prefab is spawned over the network.
At runtime there is more information to display here (a disabled NetworkBehaviour is displayed non-bold):
Property | Description |
---|---|
assetId | This identifies the prefab associated with this object (for spawning). |
clientAuthorityOwner | The client that has authority for this object. This will be null if no client has authority. |
connectionToClient | The NetworkConnection associated with this NetworkIdentity. This is only valid for player objectsA High Level API (HPAPI) object that represents the player on the server and has the ability to run commands (which are secure client-to-server remote procedure calls) from the player’s client. More info See in Glossary on the server. |
connectionToServer | The NetworkConnection associated with this NetworkIdentity. This is only valid for player objects on a local client. |
hasAuthority | True if this object is the authoritative version of the object. This would mean either on a the server for normal objects, or on the client with localPlayerAuthority. |
isClient | True if this object is running on a client. |
isLocalPlayer | This returns true if this object is the one that represents the player on the local machine. |
isServer | True if this object is running on the server, and has been spawned. |
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 NetworkTransformA Networking component that allows you to synchronize the movements of GameObjects across the network. More info See in Glossary. |
netIdA unique identifier given to an object instance to track it between networked clients and the server. More info See in Glossary |
A unique identifier for this network session, assigned when spawned. |
observers | The list of client NetworkConnections that are able to see this object. This is read-only. |
playerControllerId | The identifier of the controller associated with this object. Only valid for player objects. |
SceneId | A unique identifier for networked objects in a Scene. This is only populated in play-mode. |
serverOnly | A flag to make this object not be spawned on clients. |
NetworkIdentity
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.