开发者

Need suggestions for naming 2 classes in PHP

开发者 https://www.devze.com 2023-02-17 15:38 出处:网络
I have one class user that is initiated in /update/user.php when update.php is started. This class handles user related queries on the database, such as开发者_如何学JAVA edit, delete, create, etc.

I have one class user that is initiated in /update/user.php when update.php is started. This class handles user related queries on the database, such as开发者_如何学JAVA edit, delete, create, etc.

I'm in the process of creating a new class also named user in /src/user.php that will perform user related queries on the database but only to retrieve them (and output) them. Such as to retrieve their user id, usergroup, e-mail, etc.

I find the need to name them both user but obviously there will be conflicts when update.php is retrieved. What suggestions can you give for naming these two different classes, even though they are seperate areas in my library but perform similar operations?

Using PHP 4.


If they both query, but only one writes, then I would suggest something like.

UserWrite
UserRead

or

UserCreate
UserAccess


To present an alternative to the whole naming structure instead of just suggesting names. The Zend Framework and other libraries have a naming structure that corresponds with the file's position in the tree. Half-fictitious example:

Class name               Is in
-----------------------------------------------------------
Zend_Auth                /Zend/Auth.php
Zend_Auth_Adapter        /Zend/Auth/Adapter.php
Zend_Auth_Helper         /Zend/Auth/Helper.php
Zend_Auth_Adapter_HTTP   /Zend/Auth/Adapter/HTTP.php

so the underscore is the directory separator, and the last element of the name is the PHP file's name.

The main reason for this is that it makes autoloading extremely easy, but it's also a nice way for ordering libraries by task. Also, when you see a class used somewhere in your code, you can always tell which file it is in which is a great plus.

In your current method, the problem I see is that "src" is a very unclear description of what that class actually does. Maybe a more telling name (like "tools" or "query") would be in order, or maybe the main user class and should just be named "user"?

Applying the abovementioned example to that structure could result in

Class name                   Is in
------------------------------------------------------------
MyAppname_User_Update        /User/Update.php
MyAppname_User               /User.php

Oh and, what @Charles says in his comment. You should absolutely not be developing for PHP 4 any more. It is a dead version, and is no longer supported.


In OOP, your update.php is called BaseDAO.php and user.php is call UserDAO.php (Data Access Object). But since you don't use OOP, I guess use can name it BaseService.php and UserService.php


I would suggest you create one class to create, edit, delete, and retrieve records related to the users. Then manage user Roles to limit the access to the methods, rather than creating two separate class for one object class.

Explanation with comparison to real world.

Let's say we have class Car. When user with Mechanical Role (or a mechanic) uses the car class then, he will able to access methods like repair(), openHood(), where as when users with driving role (or drivers) will access drive() methods.

In this scenarios also it is very inappropriate to create CarMechanic class and CarDriver class.

I think I made my point.


I understand your question, but do you think that you really want to create 2 different classes to perform the same action? You can just create it in /src/user.php and obviously can use it wherever you want. You should make methods in that class in such a way that they will be used in both the problems. i.e in retrieving information and also in updating it.

0

精彩评论

暂无评论...
验证码 换一张
取 消