Today, many electronic devices such as printers, scanners, copiers, all-in-one systems, etc., are connected to a network and are accessed and used by users remotely. In addition to regular use, electronic devices often need to be monitored for problems, reconfigured, or otherwise managed. Managing network devices may be performed in either “out-of-band” or “in-band” fashion. In out-of-band management, the device is managed through a dedicated physical management port. In in-band management, the device is managed through a network to which it is connected.
The following detailed description references the drawings, wherein:
As discussed above, some network devices, such as devices that do not have a designated physical management port, may be managed through the network to which they are connected. In order to communicate with a device through a network, the device's network address (e.g., IP address) may be required. The network address may be assigned to a device when the device is first connected to the network or when it is subsequently disconnected from and reconnected to the network. In some cases, the network address may be assigned automatically, e.g., by a designated Dynamic Host Configuration Protocol (DHCP) server. In other cases, the network address may be manually assigned, e.g., by the network administrator.
The assigned network address may sometimes be retrieved by the user using the device's user interface. Some devices, however, may not have a display or may not be configured to show their network address through the user interface. Managing such devices may be problematic because, as mentioned above, the device's network address may be required in order to access it through the network. Thus, a technician attaching a new network device to the network may be unable to check its status or configure the device if the technician cannot ascertain the network address that was assigned to the device upon connection.
Examples disclosed herein describe, among other things, a computing device. The computing device may include, among other things, a detection engine to wirelessly detect an identifier of a network device communicatively coupled to a network. The computing device may also include a communication engine to access the network to obtain, based on the identifier, a network address associated with the network device, and to communicate with the network device through the network using the network address.
Network device 150 may include any electronic device or combination of electronic devices that can be communicatively coupled to a network (e.g., network 170). Such electronic devices may include, for example, printers, scanners, copiers, all-in-one systems, home appliances, servers, routers, desktop computers, laptops, tablet computers, TVs, smartphones, or any other type of electronic equipment. In some examples, network device 150 may not support out-of-band management, for example, due to lack of a dedicated physical management port, but may support in-band management. In some examples, the network address assigned to network device 150 may not be ascertainable through interfacing with the device via the user interface. For example, network device 150 may not have a display or may not be configured to show its assigned network address on the display.
Network 170 may be any combination of wired, wireless, wide-area, and local-area networks, and may include any number of hubs, routers, switches, cell towers or the like. Network 170 may be, for example, part of a cellular network, part of the Internet, part of an intranet and/or other type of network. As discussed above, network device 150 may be communicatively coupled to network 170 either wirelessly or via a cable, and upon connecting to network 170, network device 150 may be assigned (or associated with) a network address such as an IP address. In some examples, when network device 150 is disconnected and then reconnected to network 170 it may be assigned a new network address.
Computing device 110 may include any electronic device or a combination of electronic devices that can be communicatively coupled to a network (e.g., network 170). For example, computing device 110 may be a desktop computer, a laptop computer, a tablet, a smartphone, a cell phone, a digital camera, or any other electronic device or combination thereof. As illustrated in
In some examples, detection engine 112 may be configured to detect and identify network device 150. Specifically, detection engine 112 may be configured to detect an identifier of network device 150 when computing device 110 is located in the vicinity of (e.g., within a predefined distance from) network device 150. An identifier of network device 150 may include any type of data (e.g., numerical, alphanumerical, graphical, etc.) that is associated with network device 150 and that identifies it (in some examples, uniquely) among other network devices communicatively coupled to network 170. For example, an identifier may be a Media Access Control (MAC) address, a serial number, a manufacturer name, a model number, or any combination of these or other types of information describing the device.
In some examples, detection engine 112 may detect the identifier of network device 150 wirelessly. This may include detection in visible light spectrum, infrared spectrum, radio-frequency (RF) spectrum, and so forth. In some examples, network device 150 may exchange its identifier with detection engine 112 using a radio-frequency identification (RFID) system.
In other examples, the identifier may appear (or be visually represented) on, at, or near network device 150. For example, the identifier may appear on a side of network device 150, on top of network device 150, or on any other face or surface of network device 150. The identifier may be written, inscribed, or imprinted on network device 150; it may appear on a label coupled to network device 150; or it may be otherwise visually present on, at, or near network device 150. The identifier may be represented using a number, an alphanumeric value, a barcode, a quick response (QR) code, or using any other method of representation.
In these examples, computing device 110 may include a camera or an image sensor with which computing device 110 may capture an image of at least a portion of the network device 150 and/or its vicinity, such that the image includes the identifier of network device 150. For example,
Detection engine 112 may process image 120 to detect any identifiers present within the image. In some examples, detection engine 112 may use Optical Character Recognition (OCR) algorithms to detect and decode any characters, numbers or symbols present in the image. In some examples, engine 112 may use barcode detection algorithms and QR-code detection algorithms to detect and decode any barcodes or QR codes within the image. In the example of
When at least one identifier is detected and decoded by detection engine 112, the identifier may be provided by detection engine 112 to communication engine 114. After obtaining the identifier, communication engine 114 may be configured to access network 170 (e.g., through any suitable means such as Wi-Fi, cellular network, satellite network, cable, etc.) and to obtain, based on the identifier, a network address associated with network device 150. Depending on the type of network 170 and the preferred communication protocol, a network address may be an IP address or any other type of address uniquely identifying network device 150 on network 170 and allowing other devices on network 170 to address and communicate with network device 150.
In some examples, in order to obtain the network address based on the identifier, communication engine 114 may send a query to a designated server, such as a DHCP server, of network 170. The query may include the identifier of network device 150, such as its MAC address. The designated server may be configured to send to communication engine 114 a query response that includes the network address (e.g., the IP address) associated with the identifier, and therefore, with network device 150.
Alternatively or additionally, communication engine 114 may send queries to a plurality of network addresses. For example, communication engine 114 may determine the range of all possible network addresses within network 170, and then send queries to all network addresses within that range, e.g., sequentially. In response to each query, communication engine 114 may receive either an error message or no message at all if no device on network 170 is associated with the specified network address, or a reply message containing an identifier associated with the network device associated with the particular network address. For example, the query may be a “ping” message sent over an Internet Control Message Protocol (ICMP) to a particular IP address, and the reply to such “ping” message may include the MAC address of a device associated with the IP address, if such device exists.
As another example, a query may include a Simple Network Management Protocol (SNMP) request sent to a particular IP address. As in the previous example, if the particular IP address is associated with a network device, engine 114 may receive in response to the request an SNMP reply containing one or more identifiers associated with that network device, for example, in the form of a Management Information Base (MIB) object. Otherwise, engine 114 may receive an error message.
After sending a query to a given network address and receiving a response other than an error message, communication engine 114 may compare one or more identifiers detected by detection engine 112 with one or more identifiers contained in the response. In some examples, if at least one of the identifiers obtained from detecting engine 112 matches at least one of the identifiers contained in the response, communication engine 114 may determine that the given network address is associated with network device 150.
After determining the network address assigned to network device 150, communication engine 114 may use the network address to communicate with network device 150. For example, communication engine 114 may receive from network device 150 information such as its identification information, status information, error messages, configuration data, supported capabilities, and so forth. Communication engine 114 may also send to network device 150, and/or to another device responsible for managing network device 150 or network 170, updated or additional information associated with network device 150. Additional information may include, for example, network device's 150 geographical location that may be obtained, for example, by computing device 110 using a Global Positioning System (GPS) module included therein or coupled thereto. In some examples, communication engine 114 may also communicate with network device 150 to reconfigure, control, or otherwise manage the device.
In some examples, some or all of the above-described functionality (e.g., detecting an identifier, decoding the identifier, accessing the network to obtain the network address, and communicating with the network device using the network address) may be performed automatically, without requiring any action or acknowledgement by the user. For example, when computing device 110 is brought (e.g., by a user) into the vicinity of network device 150 (and in some examples, when its camera 116 faces network device 150) computing device 110 may automatically (without any acknowledgement or other action by the user) detect and decode the identifier as described above, and then automatically access the network to determine the network address of network device 150 based on the identifier as described above. Furthermore, after obtaining the network address, computing device 110 may automatically communicate with network device 150 using the determined network address in order to obtain its information and present the obtained information to the user, e.g., on display 118.
Alternatively, as illustrated in the example of
In the foregoing discussion, engines 112 and 114 were described as any combinations of hardware and programming. Such components may be implemented in a number of fashions. The programming may be processor executable instructions stored on a tangible, non-transitory computer-readable medium and the hardware may include a processing resource for executing those instructions. The processing resource, for example, may include one or multiple processors (e.g., central processing units (CPUs), semiconductor-based microprocessors, graphics processing units (GPUs), field-programmable gate arrays (FPGAs) configured to retrieve and execute instructions, or other electronic circuitry), which may be integrated in a single device or distributed across devices. The computer-readable medium can be said to store program instructions that when executed by the processor resource implement the functionality of the respective component. The computer-readable medium may be integrated in the same device as the processor resource or it may be separate but accessible to that device and the processor resource. In one example, the program instructions can be part of an installation package that when installed can be executed by the processor resource to implement the corresponding component. In this case, the computer-readable medium may be a portable medium such as a CD, DVD, or flash drive or a memory maintained by a server from which the installation package can be downloaded and installed. In another example, the program instructions may be part of an application or applications already installed, and the computer-readable medium may include integrated memory such as a hard drive, solid state drive, or the like. In another example, the engines 112 and 114 may be implemented by hardware logic in the form of electronic circuitry, such as application specific integrated circuits.
At block 505, method 500 may obtain an image representing at least a portion of a network device (e.g., network device 150) connected to a network (e.g., network 170). At block 510, the method may extract from the image an identifier of the network device. As described above, the identifier may be, for example, a MAC address or a serial number of the network device. In some examples the identifier may be represented on the portion of the network device in a form of an alphanumerical value, a barcode, a QR code, or any combination of these and other types of representation. At block 515, the method may connect to the network to obtain a network address (e.g., an IP address) of the network device based on the identifier. For example, as discussed above, obtaining the network address based on the identifier may include querying a server (e.g., a DHCP server) connected to the network. In some examples, the server may include a database of identifiers (e.g., MAC addresses) and network addresses (e.g., IP addresses) associated therewith. Alternatively or additionally, obtaining the network address may include querying a plurality of network devices connected to the network, as discussed above. At block 520, the method may manage the network device through the network using the obtained IP address, as discussed above.
Processor 610 may be one or more central processing units (CPUs), microprocessors, and/or other hardware devices suitable for retrieval and execution of instructions stored in non-transitory machine-readable storage medium 620. In the particular example shown in
Non-transitory machine-readable storage medium 620 may be any electronic, magnetic, optical, or other physical storage device that stores executable instructions. Thus, medium 620 may be, for example, Random Access Memory (RAM), an Electrically-Erasable Programmable Read-Only Memory (EEPROM), a storage drive, an optical disc, and the like. Medium 620 may be disposed within computing device 600, as shown in
Referring to
Instructions 624, when executed by a processor, may cause a computing device to determine the unknown network address based on the identifier. As discussed above, this may include accessing a DHCP server and/or accessing the network device itself.
Instructions 626, when executed by a processor, may cause a computing device to connect to the network device through the network using the determined network address. Instructions 628, when executed by a processor, may cause a computing device to communicate with the network device. As discussed above, the communication may include receiving device information associated with the network device and/or sending configuration information for configuring the network device.
| Filing Document | Filing Date | Country | Kind |
|---|---|---|---|
| PCT/US2015/010833 | 1/9/2015 | WO | 00 |